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前 Ei 


PHP 自 诞生 之 日 起 ， 由 于 其 开源 性 ， 注 定 了 它 有 很 强 的 生命 力 。 目 前 ， 它 已 经 成 为 最 
流行 的 Web 程序 开发 语言 之 一 。 在 国内 ，PHP 在 很 短 的 时 间 内 得 到 了 飞速 发 展 ， 几 乎 所 有 
的 虚拟 主机 和 绝 大 多 数 的 服务 器 都 提供 了 PHP 支持 。PHP 作为 一 门 功能 强大 的 Web 编程 
语言 ， 以 其 简单 易学 、 安 全 可 靠 和 器 平台 等 优点 受到 广大 Web 开发 人 员 的 喜爱 ， 成 为 越 来 
越 多 程序 员 的 首选 编程 语言 。 


本 书 特点 


在 编写 本 书 前 ， 编 者 仔细 梳理 了 PHP 各 相关 知识 模块 之 间 的 逻辑 关系 。 在 内 容 编排 上 
严格 遵循 PHP 各 知识 点 的 基础 与 上 层 的 关系 ， 步 步 为 营 、 层 层 递 进 ， 务 求 使 读者 能 快速 党 
握 PHP 综合 编程 能 力 。 本 书 中 的 每 个 知识 点 都 是 先 以 简短 的 篇 幅 介绍 其 中 最 基本 、 最 常用 
的 内 容 ， 然 后 通过 精心 设计 的 一 些 典型 案例 ， 介 绍 程序 设计 的 基本 方法 ， 避 免 了 常见 程序 
设计 类 图 书 的 枯燥 和 空洞 ， 使 读者 在 不 知 不 觉 之 中 就 学 会 了 如 何 利用 PHP 实现 Web 编程 。 

概括 来 讲 ， 本 书 具 有 如 下 特点 : 

@ ”取材 广泛 ， 注重 实 际 应 用 。 本 书 所 有 案例 都 是 作者 从 日 常 教学 和 生活 中 送 选 出 来 

的 典型 案例 ， 具 有 很 强 的 代表 性 ， 实 际 应 用 性 强 。 
@ ”案例 完整 ， 结 构 清晰 。 本 书 中 的 大 小 案例 有 数 百 个 ， 各 案例 力求 功能 齐全 ， 其 代 
码 实现 由 浅 入 深 、 循序 渐进 。 

@ 讲解 通俗 ， 步 骤 详 细 。 每 个 案例 的 开发 步骤 都 以 通俗 易 懂 的 语言 进行 阐述 ， 并 穿 
插 了 大 量 的 图 片 和 表格 。 
代码 准确 ， 注 释 清 晰 。 本 书 所 有 案例 的 代码 都 有 详尽 的 注释 ， 以 便于 读者 理解 核 
心 代码 的 功能 和 风 辑 意义 。 

@ ”配套 资料 齐全 ， 网 上 免费 下 载 。 本 书 所 有 案例 的 代码 、 经 笔者 精心 收集 的 相关 软 

件 及 学 习 资源 都 可 通过 清华 大 学 出 版 社 网 站 下 载 ， 以 方便 读者 学 习 。 


组 织 结构 


本 书 详细 介绍 了 在 Windows 环境 下 利用 PHP 进行 Web 编程 的 基本 方法 , 包括 PHP 程 
序 运行 环境 的 配置 、PHP 基本 语法 、PHP 系统 内 置 函数 与 用 户 自 定义 函数 、 在 PHP 程序 中 
对 文件 和 目录 的 操作 、MySQL 数据 库 的 安装 与 应 用 、PHP 与 MySQL 结合 进行 数据 库 编程 、 
正则 表达 式 的 概念 与 应 用 、 面向 对 象 编程 技术 和 在 Dreamweaver CS4 环境 中 实现 PHP 编程 
等 。 本 书 大 部 分 章节 后 面 都 附 有 丰富 的 练习 题 和 上 机 实战 ， 有 助 于 读者 复习 、 巩 固 所 学 知 
识 ， 培 养 读 者 的 实际 编程 能 力 。 

此 外 ， 为 满足 教学 的 实际 需要 ， 本 书 在 第 12 章 还 给 出 了 PHP+MySQL+Apache 项 目 开 
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发 环境 的 简易 配置 方法 以 及 成 绩 管 理 系统 和 用 户 管理 系统 的 设计 与 实现 两 个 实验 指导 。 书 
中 所 有 实例 程序 代码 都 已 调试 通过 ， 且 运行 无 误 。 

本 书 适 用 于 高 等 学 校 计算 机 类 和 信息 管理 类 专业 的 Web 编 程 技术 课程 及 相似 课程 的 教 
学 ， 建 议 安排 课时 总 量 为 64 课时 ， 其 中 理论 教学 课时 为 40， 实 验 课时 为 24。 


读者 对 象 


应 用 型 本 科 院 校 相 关 专 业 学 生 
高 职高 专 院 校 相 关 专业 学 生 
计算 机 培训 教师 和 学 员 

Web 编程 爱好 者 和 相关 技术 人 员 
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知识 点 : 


PHP 的 由 来 
PHP 能 做 什么 
PHP 运行 环境 
PHP 运行 的 原理 
编辑 PHP 程序 代码 的 常用 工具 
本 章 导读 : 

PHP 是 一 种 简单 而 强大 的 开源 脚本 语言 ， 用 于 创建 动态 Web 内 容 ， 功 能 和 ASP 相似 。 
本 章 首先 介绍 了 动态 Web 站 点 的 概念 ， 然 后 对 PHP 的 概念 和 原理 进行 了 阐释 ， 接 着 介绍 
了 PHP 的 运行 环境 及 其 配置 ， 为 了 让 读者 尽快 熟悉 PHP 语言 的 特点 ， 编 者 在 最 后 介绍 了 
几 款 常用 的 PHP 程序 代码 编辑 工具 


网 罗网 罗网 


1.1 动态 Web 站 点 


在 Intemet 上 用 户 可 以 使 用 很 多 服务 , 其 中 Web 服务 是 目前 Intemet 上 非常 重要 、 使 用 
也 最 多 的 一 项 服务 。Web 服务 器 上 的 各 个 超 文本 文件 称 为 网 页 ， 而 存放 这 些 网 页 的 Web 
服务 器 称 为 Web 站 点 。 


1.1.1 什么 是 动态 Web 站 点 


动态 Web 站 点 的 内 容 会 在 用 户 每 次 访问 或 重 载 站 点 时 重新 生成 ,该 网 页 文件 不 仅 具有 
HTML 标记 ， 而 且 含 有 程序 代码 ， 用 于 数据 库 连 接 。 动 态 网 页 能 根据 不 同 的 时 间 和 不 同 的 
来 访 者 显示 不 同 的 内 容 ， 且 更 新 方便 ， 一 般 在 后 台 直 接 更 新 。 动 态 网 站 中 的 网 页 广泛 采用 
通用 网 关 接 口 (CGI) 技术， 该 技术 能 够 将 用 户 客户 端 浏览 器 上 输入 的 数据 提交 到 Web 服务 器 
上 运行 ， 然 后 将 运行 结果 返回 到 用 户 的 浏览 器 上 ; 采用 的 语言 一 般 为 ASP、PHP 和 Java 等 。 


1.1.2 ”从 静态 网 站 到 动态 网 站 的 演变 


静态 网 页 是 网 站 建设 的 基础 ， 静 态 网 页 和 动态 网 页 之 间 相 互 依存 ， 共 同 支 持 网 页 的 运 
行 。 动 态 网 站 中 的 大 多 数 网 页 具有 交互 筛选 功能 ， 其 页 面 可 根据 用 户 的 需求 显示 不 同 的 信 
息 内 容 。 与 动态 网 站 相反 ， 静 态 网 站 没有 交互 的 功能 。 在 URL 表现 形式 上 ， 每 个 静态 网 页 
都 有 一 个 固定 的 URL， 而 且 网 页 的 URL 以 .htm、.html、.shtml 等 常见 形式 为 后 级 ， 而 不 含 
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有 “? ”。 在 网 站 的 内 容 上 ， 静 态 网 页 内 容 发 布 到 网 站 服务 器 上 后 ， 无 论 是 否 有 用 户 访问 ， 

每 个 静态 网 页 的 内 容 都 是 保存 在 网 站 服务 器 上 的 ， 每 个 网 页 都 是 一 个 独立 的 文件 ， 且 内 容 

相对 稳定 。 在 网 站 维护 方面 ， 静 态 网 页 一 般 没有 数据 库 的 支持 ， 因 此 在 网 站 制作 和 维护 方 

面 工作 量 较 大 ， 当 网 站 信息 量 很 大 时 仅仅 依靠 静态 网 页 来 发 布 网 站 内 容 变 得 非常 困难 。 
基于 上 述 静 态 网 站 的 诸多 缺陷 ， 动 态 网 站 为 用 户 提 供 了 如 下 强大 的 功能 。 

口 ”动态 网 页 以 数据 库 技术 为 基础 ， 可 以 大 大 降低 网 站 维护 的 工作 量 。 

口 采用 动态 网 页 技术 的 网 站 可 以 实现 更 多 的 功能 ， 如 网 上 在 线 商务 等 。 

口 ”根据 终端 用 户 不 同 的 需求 返回 不 同 内 容 的 网 页 ， 具 有 按 需 定制 网 页 内 容 的 功能 。 

当然 ， 由 于 动态 网 页 上 的 信息 必须 从 数据 库 中 读 取 ， 即 每 打开 一 个 网 页 都 要 读 取 一 次 

数据 库 ， 因 此 ， 如 果 在 线 访问 人 数 过 多 ， 就 会 影响 网 站 的 运行 速度 。 但 随 着 现代 计算 机 技 

术 的 不 断 发 展 ， 这 已 不 再 是 什么 问题 。 


1.2 PHP 基本 原理 及 由 来 


PHP 究竟 是 一 种 什么 样 的 语言 ? 它 是 怎样 产生 和 发 展 起 来 的 ? 下 面 将 详细 说 明 这 两 个 


问题 。 
1.2.1 PHP 概念 


PHP 是 Hypertext Preprocessor 〈 超 文本 预 处 理 器 ) 的 字母 缩写 ， 是 一 种 广泛 使 用 的 服 
务 器 端 编 程 语 言 ， 用 于 开发 动态 网 页 。PHP 是 一 种 开源 的 、 跨 平台 的 、 独 立 于 架构 的 、 解 
释 的 、 面 向 对 象 的 、 快 速 的 、 健 壮 的 、 安 全 性 高 的 Web 编程 语言 。 它 借鉴 了 C、Java、Perl 
等 语言 的 部 分 语法 并 结合 PHP 自身 的 特性 ， 使 一 般 的 初学 者 能 很 快 上 手 并 熟练 运用 ， 让 
Web 开发 者 能 快速 地 写 出 动态 生成 页 面 的 脚本 。 

与 ASP 和 JSP 不 同 , PHP 是 一 个 开放 源 代码 的 项 目 ， 所 以 没有 购买 许可 证 的 费用 或 限 
制 使 用 的 问题 ， 用 户 完全 可 以 使 用 PHP 来 开发 中 小 型 的 Web 项 目 ， 而 且 开发 成 本 几乎 为 
零 。 除 此 之 外 ,用户 还 可 以 通过 互联 网 获取 大 量 的 帮助 信息 。 如 果 读 者 是 一 个 PHP 编程 经 
给 丰 富 的 高 手 ， 且 富有 志愿 者 的 精神 ， 也 可 以 将 自己 的 优秀 源 代 码 上 传 到 相关 的 PHP 网 站 
上 去 ， 与 他 人 分 享 自己 的 杰作 。 


1.2.2 PHP 的 产生 与 发 展 


任何 新 生 事物 都 有 其 产生 和 发 展 的 过 程 ，PHP 也 不 例外 。PHP 的 创始 人 是 Rasmus 
Lerdorf。1994 年 ， 他 用 Perl 语言 编写 了 一 个 简单 程序 ， 用 来 统计 自己 网 站 的 访问 情况 ， 后 
来 他 又 用 C 语言 重新 进行 了 编写 , 增加 了 连接 数据 库 等 功能 , 并 在 1995 年 以 Personal Home 
Page Tools (PHP Tools) 开始 对 外 发 表 第 一 个 版 本 PHP 1.0。 在 早期 的 PHP 版 本 中 ， 仅 提 
供 了 访客 留言 本 、 访 客 计 数 器 等 简单 的 功能 。 此 后 ， 越 来 越 多 的 网 站 使 用 了 PHP， 并 且 强 
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烈 要 求 增加 一 些 特性 , 如 循环 语句 和 数组 变量 等 。 随 着 PHP 开发 团队 的 不 断 壮大 ,在 PHP 1.0 
版 本 发 布 之 后 不 久 ，PHP 2.0 很 快 也 发 布 了 ， 并 命名 为 PHP/FI (Form Interpreter) 。PHP/FI 
加 入 了 对 MySQL 的 支持 ， 从 此 建立 了 PHP 在 动态 网 页 开发 上 的 地 位 。 到 了 1996 年 底 ， 有 
15000 个 网 站 使 用 PHP/FI。 到 了 1997 年 ， 使 用 PHP/FI 的 网 站 数字 超过 5 万 个 。 

1997 年 ，PHP 开发 小 组 开始 了 第 三 版 的 开发 计划 。Zeev Suraski 及 Andi Gutmans 等 
人 加 入 到 PHP 开发 团队 之 后 ， 对 PHP 进行 了 彻底 崭新 的 设计 ， 在 加 入 了 许多 新 功能 和 新 
技术 的 基础 上 推出 了 PHP 的 第 三 版 PHP 3.0。2000 年 ，PHP 4.0 又 问世 了 ， 其 中 又 增加 了 
许多 新 的 特性 ， 使 PHP 更 加 成 熟 ， 其 核心 引擎 更 加 优越 ， 执 行 速度 更 快 ， 已 比 传统 的 CGI 
及 ASP 等 程序 有 更 好 的 表现 和 更 丰富 的 函数 库 支持 。 

PHP 进入 中 国 较 晚 ， 在 很 长 一 段 时 间 内 ，PHP 的 使 用 率 很 低 。 但 是 最 近 几 年 ，PHP 以 
其 易学 、 高 效 、 安 全 、 免 费 、 跨 平台 等 一 系列 重要 优势 ， 在 国内 迅速 发 展 起 来 。 现 在 ， 国 
内 已 经 出 现 大 量 采用 PHP 开发 的 网 站 。 

目前 ，PHP 的 最 新 版 本 是 PHP 5， 它 在 PHP4 的 基础 上 进行 了 进一步 的 改进 ， 功 能 更 
强大 ， 执 行 效率 更 高 。 


1.2.3 PHP 原理 


根据 PHP 程序 的 代码 执行 过 程 和 工作 机 制 ， 可 以 把 PHP 网 络 程序 的 运行 原理 描述 为 
如 图 1-1 所 示 的 6 个 步骤 。 


Fr----------------------------------- 


1. 请 求 一 个 网 页 文件 2 要求 处 理 FiP 脚本。 ”要 求 处 理 数 
mn 
6。 改 半生 成 的 纯 HIML 文件 5. 3 
图 1-1 PHP 原理 图 
下 面 对 照 图 1-1， 对 PHP 原理 做 进一步 的 阐释 。PHP 程序 的 一 个 完整 运行 周期 大 致 包 
括 如 下 6 个 步骤 ; 


(1) 用 户 通过 浏览 器 向 Web 服务 器 发 起 一 个 PHP 网 页 文件 请 求 。 

(2) Web 服务 器 接收 到 请 求 后 读 取 所 请 求 的 文件 ， 如 果 扩 展 名 为 php， 则 向 PHP 模 
块 发 送 PHP 代码 的 请 求 。 

(3) 如 果 脚 本 中 还 有 数据 库 操作 语句 ，PHP 模块 建立 与 MySQL 的 数据 库 连 接 将 SQL 
命令 发 送 到 MySQL。 

(4) MySQL 进行 数据 库 处 理 操作 ， 并 将 操作 结果 返回 给 PHP 模块 。 

(5) PHP 模块 处 理 完 PHP 脚本 ， 将 结果 返回 给 Web 服务 器 。 

(6) Web 服务 器 最 终 将 纯 HIML 数据 返回 给 客户 端 浏 览 器 , 浏览 器 显示 HTML 页 面 。 

通过 分 析 以 上 步骤 不 难 发 现 , PHP 程序 通过 Web 服务 器 接收 访问 请 求 ， 在 服务 器 端 处 
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理 请 求 ， 然 后 通过 Web 服务 器 向 客户 端 发 送 处 理 结果 。 在 客户 端 接 收 到 的 只 是 程序 输出 的 
处 理 结果 ， 是 一 些 HTML 标记 ， 无 法 直接 看 到 PHP 代码 ， 这 样 就 能 够 很 好 地 保证 代码 的 
保密 性 和 程序 的 安全 性 。 


1.3 PHP 的 运行 环境 


PHP 编程 人 员 想 要 得 心 应 手 地 运用 PHP 开发 各 种 Web 项 目 ， 了 解 PHP 运行 的 软件 和 
硬件 环境 的 知识 是 必 不 可 少 的 。 除 此 之 外 ， 还 要 正确 地 安装 和 配置 配套 PHP、MySQL、 
Apache 等 系统 软件 ， 进 而 搭建 好 整个 PHP 的 开发 环境 。 本 节 只 介绍 PHP、Apache 安装 和 
配置 ，MySQL 安装 和 配置 将 在 第 6 章 介绍 MySQL 数据 库 系 统 时 一 并 讲解 。 


1.3.1 PHP 运行 的 软 硬 件 环境 


PHP 和 其 他 系统 软件 一 样 ， 都 需要 具有 硬件 和 软件 环境 的 支持 。PHP 对 硬件 的 要 求 非 
常 低 ， 对 一 般 初 学 者 来 说 ， 拥 有 一 台 普 通 的 计算 机 就 足够 了 。 软 件 环境 主要 包括 操作 系统 
和 Web 服务 软件 ， 二 者 可 根据 用 户 的 实际 情况 和 需要 来 进行 选择 。 

PHP 能 够 在 目前 所 有 的 主流 操作 系统 上 运行 , 包括 Linux、UNIX (包括 HP-UX、 Solaris 
和 OpenBSD 等 ) 、Microsoft Windows 系列 、Mac OS 等 。PHP 在 这 些 平 台 上 的 安装 步骤 大 
同 小 异 ， 不 再 一 一 介绍 。 本 书 将 以 Windows 平台 为 例 ， 介 绍 PHP 的 安装 和 使 有 用。 事实 上 ， 
由 于 PHP 具有 可 移植 性 ， 所 以 在 程序 设计 阶段 使 用 什么 样 的 操作 系统 无 关 紧 要 ， 因 为 开发 
出 来 的 程序 可 以 非常 容易 地 移植 到 其 他 操作 系统 上 去 。 

Web 服务 软件 也 称 为 Web 服务 器 ， 目 前 ， 业 界 用 得 最 多 的 主要 有 两 种 Web 服务 器 ， 

-种 是 微软 公司 的 IIS 服务 器 ， 另 外 一 种 是 Apache 服务 器 ，PHP 对 这 两 种 Web 服务 器 都 
能 很 好 地 支持 。 下 面 将 只 对 Apache 服务 器 在 Windows 环境 下 的 安装 和 配置 过 程 进 行 详细 
介绍 。 同 时 ， 如 无 特别 说 明 ， 本 书 中 所 涉及 的 实例 源 代 码 ， 都 是 通过 Apache 服务 器 进行 测 
试 的， 程序 运行 的 显示 结果 也 是 在 Apache 平台 上 的 执行 结果 。 


1.3.2 ”Apache 的 安装 及 服务 器 配置 


Apache 是 世界 上 使 用 最 为 广泛 的 Web 服务 器 之 一 ， 根 据 NetCraft 机 构 的 调查 ， 世 界 
上 50% 以 上 的 Web 服务 器 是 用 Apache 搭建 的 。 

1995 年 4 月 , 最 早 的 Apache 0.6.2 版 由 Apache Group 公布 发 行 。 Apache Group 是 一 个 
非 需 利 的 机 构 ， 因 此 ，Apache 版 本 的 更 新 以 及 标准 发 行 版 中 应 包含 哪些 内 容 等 日 常 运作 都 
是 在 互联 网 上 进行 的 。 Apache 是 一 款 开发 源 代码 软件 ,允许 任何 人 对 其 修改 、 扩充 和 更 新 ， 
正 因为 如 此 ， 才 保持 了 强大 的 生命 力 。 目 前 ，Apache 的 最 新 版 本 是 Apache 2.2.15。 

和 其 他 服务 器 相 比 ，Apache 拥有 以 下 特性 : 

口 “几乎 所 有 的 计算 机 平台 都 支持 Apache 运行 。 
口 支持 HITP 协议 的 最 新 版 本 HITP/1.1 协议 。 
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所 有 的 服务 器 其 配置 操作 都 可 以 通过 httpd.conf 文件 进行 ， 操 作 方便 简单 。 
支持 通用 网 关 接口 (CGI) 、FASTCGI。 支 持 虚拟 主机 ， 支 持 HTTP 认证 。 
具有 对 用 户 会 话 过 程 的 跟踪 能 力 。 
支持 Java Serverlets。 
运行 效率 高 ， 成 本 低 。 

Apache 是 免费 软件 ， 因 此 获取 Apache 安装 文件 的 途径 有 很 多 ， 但 最 好 从 其 官方 网 站 
上 下 载 。Apache 官方 网 站 的 URL 地 址 为 http://www.apache.org， 如 图 1-2 所 示 为 网 站 首页 
单 击 首页 上 部 的 Download 菜单 ， 进 入 Apache 最 新 版 本 的 服务 器 产品 列表 ， 找到 
Apache 2.2.15 列表 项 (如 图 1-3 所 示 ) ， 单 击 该 项 下 部 的 Download 超 链接 ， 进 入 如 图 1-4 
所 示 的 下 载 页 面 。 由 于 大 多 数 初学 者 学 习 PHP 都 选择 Windows 平台 , 故 在 此 选择 Windows 
环境 下 的 安装 程序 httpd-2.2.15-win32-x86-openssl-0.9.8m-r2.msi 进行 下 载 。 
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图 1-4 Apache 服务 器 安装 文件 的 下 载 页 面 


将 安装 文件 httpd-2.2.15-win32-x86-openssl-0.9.8m-r2.msi 成 功 下 载 到 本 地 磁盘 后 , 用 鼠 
标 双 击 进 入 安装 向 导 欢 迎 界面 ， 如 图 1-5 所 示 。 单 击 Next 按钮 ， 出 现 软 件 安 装 使 用 许可 协 
议 说 明 窗 口 ， 在 此 选中 Iaccept the terms in the License Agreement 单 选 按钮 来 接受 许可 协议 
条 款 。 再 单 击 Next 按钮 ， 出 现 一 个 关于 Apache 的 一 些 相 关 介绍 ， 阅 读 完 此 介绍 信息 后 ， 
单 击 Next 按钮 进入 Apache 服务 器 域名 权限 等 配置 窗口 ， 如 图 1-6 所 示 。 该 窗口 有 3 个 文 
本 框 , 分 别 要 求 输入 网 络 域名 、 服 务 器 名 、 管 理 员 信箱 , 以 及 一 组 单 选 按钮 , 要 求 选择 Apache 
的 工作 方式 。 如 果 是 将 本 地 机 作为 服务 器 ， 前 3 项 可 以 为 空 ， 不 需 设 置 。 第 4 个 选项 有 两 
种 选择 ， 系 统 推 荐 使 用 第 一 种 , 即 for All Users，on Port 80，as a Service--Recommended (中 
文 意思 是 : 针对 所 有 用 户 ， 工 作 在 80 端口 ， 作 为 服务 器 -- 推 荐 ) 。 
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图 1-5 Apache 安装 程序 欢迎 界面 图 1-6 Apache 服务 器 的 配置 


设置 完成 之 后 , 单 击 Next 按钮 出 现 选择 安装 类 型 的 界面 ,如 图 1-7 所 示 。 其 中 ,Typical 
选项 是 典型 安装 Apache 服务 器 ， 适 合 大 多 数 使 用 者 ; Custom 选项 为 用 户 自 定义 安装 
Apache 服务 器 ， 适 合十 分 熟悉 Apache 的 用 户 选择 。 作 为 初学 者 ， 建 议 选择 Typical 典型 

设置 完 服务 器 安装 类 型 后 ， 单 击 Next 按钮 进入 下 一 步 ， 出 现 Apache 安装 位 置 的 选择 
窗口 ， 在 此 用 户 可 以 自由 选择 安装 的 目标 目录 。 设 置 好 安装 位 置 后 ， 单 击 Next 按钮 ， 系 统 
会 出 现 “ 安 装 准备 已 就 绪 ” 的 提示 界面 ， 单 击 Install 按钮 开始 安装 ， 随 即 进入 如 图 1-8 所 
示 的 安装 界面 。 
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pache MTTP Server 2.2 ~ Instal1e0I on TT 
Setup Type Installing Apache HTTP Server 2.2.15 
Choose the setup type that best ss your needs, The program features you selected are being installed, 


Please select a setup type, 唱 于 the Installation Wizard instals Apache HTTP Server 


2.2.15. ee 


PR 
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Choose which program features you wank installed and where they 
wil be Instaled, For advanced users, 


图 1-7 Apache 服务 器 的 安装 类 型 设置 图 1-8 Apache 服务 器 的 安装 进度 


安装 完毕 后 , 单 击 Finish 按钮 。 如 果 安 装 成 功 , 将 在 Windows 桌面 右 下 角 出 现 呈 图 标 ， 
在 开始 程序 菜单 中 还 将 出 现 如 图 1-9 所 示 的 Apache 程序 菜单 组 。 其 中 ，Configure Apache 
Server 子 程序 组 下 面 的 Edit the Apache httpd.conf Configuration File 菜单 是 用 于 配置 Apache 
服务 器 的 文本 文件 , 用 鼠标 双击 该 菜单 ， 将 打开 一 个 名 为 httpd.conf 的 纯 文本 文件 。 通过 修 
改 此 文件 可 以 为 网 站 设置 主 目录 ( 即 默认 情况 下 网 页 文档 存放 的 位 置 ), 其 默认 值 是 Apache 
系统 目录 下 的 Apache2.2\htdocs 子 日 录 , 如 图 上 8 所 示 。 用户 可 以 通过 DocumentRoot 
修改 主 目录 ， 以 适应 自己 的 需要 , 方法 如 下 : 用 “记事 本 ”程序 打开 httpd.conf 文件 ， 
用 “编辑 ”菜单 中 的 “查找 ”命令 找到 id 命令 参数 (其 格式 为 ei 
[Path]) ， 最 后 把 Path 参数 替换 成 拟 设 为 网 站 主 目录 的 路 径 即 可 。 


< 注意 : 修改 目录 时 ， 文 件 夹 与 文件 夹 之 间 的 分 界 符 是 “/”， 而 非 Windows 目录 路 径 格 
式 下 的 “\ 符号 
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图 1-9 Apache 服务 器 程序 组 


ft Docunenthoot: The directory out of which you will serve your 
# docunents. By default, all requests are taken fron this directory, but 
# synbolic links and aliases nay be used to point te other locations. 

日 


|BucumentRoot “D:/Program Files/Apache Software Foundation/Apache2 .2/htdocs™—> 


图 1-10 配置 网 站 主 目 录 


在 httpd.conf 文件 中 ， 除 了 可 以 设置 网 站 主 目录 外 ， 还 可 以 进行 以 下 设置 。 
(1) Listen 指令 

Listen 指令 用 于 设置 Apache 服务 器 监听 的 他 地 址 和 端口 。 其 语法 格式 如 下 : 

Listen [IP-address:]portnumber 
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其 中 ,参数 了 -address 表示 下 地 址 ,参数 portmumber 表 示 端 口号 ,Listen 指令 指示 Apache 
只 在 指定 的 IP 地 址 和 端口 上 监听 默认 情况 下 Apache 会 在 所 有 他 地 址 上 监听 ) 。Listen 
一 个 必须 设置 的 指令 ， 如 果 在 配置 文件 中 找 不 到 这 个 指令 ， 服 务 器 将 无 法 启动 。Listen 
指令 指定 服务 器 在 哪个 端口 或 地 址 + 端口 的 组 合 上 监听 网 络 接 入 请 求 ， 并 对 该 地 址 或 地 址 + 
端口 组 合 上 的 请 求 做 出 应 答 。 
例如 ， 想 要 服务 器 接受 80 和 8000 端口 上 的 请 求 ， 可 以 这 样 设置 : 


Listen 80 
Listen 8000 


要 想 让 服务 器 接受 来 自 两 个 指定 IP 地址 和 端口 号 的 请 求 ， 应 采用 如 下 格式 的 指令 


Listen 192.11.2.1: 80 
Listen 192.11.2.3:8000 


同样 ， 在 设置 该 指令 前 ， 应 先 打 开 httpd.con 文件 ， 然 后 查找 此 指令 ， 再 做 修改 。 
(2) Alias 指令 

Alias 指令 用 于 映射 URL 到 文件 系统 的 特定 区 域 , 也 就 是 在 Apache 网 站 中 创建 一 个 虚 
拟 目 录 。 其 语法 格式 如 下 : 

Alias URL-path file-pathldirectory-path 

其 中 ，URL-path 表示 虚拟 路 径 ，file-path 或 directory-path 表示 本 地 文件 系统 的 物理 路 
径 。Alias 指令 可 以 使 文档 存储 在 DocumentRoot 以 外 的 本 地 文件 系统 中 。 以 URL-path 路 径 
开头 的 URL 可 以 被 映射 到 以 directory-path 开头 的 本 地 文件 中 。 

如 在 httpd.conf 文件 中 输入 指令 : 


Alias /image/ ftp/pub/image 


则 在 正 浏览 器 中 输入 http://myserver/image/foo.gif 并 按 Enter 键 后 ， 服 务 器 将 返回 
“\ftp\pub\ image\foo.gif” 文 件 到 下 浏览 窗口 中 。 


< 注意 : 如 果 URL-path 中 有 后 级 “/”"， 则 服务 器 要 求 有 后 级 “/” 以 扩展 此 别名 。 也 就 是 
说 “Alias /icons/usr/local/apache/icons/” 并 不 能 对 “/icons” 实 现 别 名 。 同 样 ， 在 
设置 该 指令 前 ， 应 先 打 开 httpd.con 文件 ， 然 后 查找 此 指令 ， 再 做 修改 。 


(3) DirectoryIndex 指令 

DirectoryIndex 指令 用 于 当 客 户 端 在 URL〈 统 一 资源 定位 符 ) 的 末尾 添加 一 个 “/” 以 
表示 请 求 该 目录 的 索引 时 ， 设 置 服务 器 以 资源 列表 的 形式 将 该 目录 内 容 返 回 给 客户 端 。 其 
语法 格式 如 下 : 

DirectoryIndex local-url [local-url] ... 

其 中 ， 参 数 local-url 表示 一 个 相对 于 被 请 求 目录 中 文档 的 URL， 通 常 是 该 目录 中 的 一 
个 文件 。 可 以 同时 指定 多 个 URL， 但 多 个 URL 之 间 必 须 用 空格 分 隔 。 服 务 器 搜索 时 ， 将 
返回 最 先 找到 的 那 一 个 目录 。 若 一 个 也 没有 找到 , 并 且 为 local-url 目录 设置 了 Indexes 选项 ， 
服务 器 将 会 自动 产生 一 个 该 目录 中 的 资源 列表 。 例 如 : 
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DirectoryIndex index.html 


上 面 的 设置 要 求 对 http://myserver/docs/ 的 请 求 返 回 http://myserver/docs/index.html( 若 
存在 ) 或 返回 该 目录 下 的 所 有 资源 列表 。 同样 ,在 设置 该 指令 前 ,应 先 打开 httpd.con 文件 ， 
查找 到 此 指令 ， 再 做 相应 修改 。 
< 注意 : 指定 的 文档 不 必 一 定位 于 被 请 求 的 目录 下 ， 也 可 以 指定 一 个 绝对 URL 以 指向 其 

他 位 置 。 例 如 : 

DirectoryIndex index.html index.txt /cgi-bin/index.pl 

这 样 的 设置 将 导致 在 index.html 或 index.txt 都 不 存在 的 情况 下 执行 CGI 脚本 
/cgi-bin/ index.p]。 


以 上 相关 设置 完毕 后 , 在 正 浏览 器 地 址 栏 中 输入 “http://localhost”， 然 后 按 Enter 键 ， 
进入 如 图 1-11 所 示 的 测试 页 面 ， 表 明 Apache 服务 器 安装 成 功 。 
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It works! 


图 1-11 Apache 服务 器 的 测试 网 页 
1.3.3 ”如 何 安装 PHP 


PHP 的 安装 可 通过 两 种 方式 : 一 种 是 从 PHP 的 官方 网 站 (www.php.net) 上 下 载 安装 
文件 压缩 包 ， 然后 解压 到 指定 的 文件 夹 中 ; 另外 一 种 方法 是 从 PHP 的 官方 网 站 上 下 载 安装 
程序 (目前 较 新 的 版 本 是 PHP 5.3.2， 其 安装 程序 是 php-5.3.2-nts-Win32-VC9-x86.msi) ， 
下 载 完毕 后 双击 鼠标 ， 进 入 PHP 安装 向 导 界 面 ， 如 图 1-12 所 示 。 

单 击 Next 按钮 ， 进 入 PHP 用 户 安装 许可 协议 ， 选 中 工 accept the terms in the License 
Agreement 单 选 按钮 来 接受 许可 协议 条 款 ， 如 图 1-13 所 示 。 

然后 单 击 Next 按钮 进入 下 一 步 ， 选 择 PHP 的 安装 路 径 ， 如 图 1-14 所 示 。 

安装 路 径 设 置 完 毕 后 ， 单 击 Next 按钮 ， 进 入 PHP 程序 ， 选 择 Web 服务 器 ， 这 里 不 选 
择 任 何 选项 〈 可 以 在 后 面 根 据 用 户 需 要 进行 灵活 的 手动 设置 完成 ， 将 在 1.3.4 小 节 中 讲 到 ) 
直接 进入 正式 安装 阶段 ， 如 图 1-15 所 示 ， 用 树 状 目录 的 形式 显示 PHP 相关 的 安装 组 件 。 
单 击 + 按钮 展开 所 有 可 安装 选项 , 在 相应 组 件 上 单 击 ,将 弹出 一 个 包括 3 个 选项 的 快捷 菜单 ， 
其 中 第 一 项 为 安装 当前 选中 的 组 件 ， 第 二 项 为 安装 所 有 组 件 ， 第 三 项 为 不 安装 任何 组 件 。 
如 果 是 开发 人 员 ， 建 议 安装 所 有 组 件 ， 如 果 是 部 署 人 员 ， 可 选择 部 分 组 件 进行 安装 。 
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End-User License Agreement 
Welcome to the PHP 5.3.2 Setup Wizard Please read the folowing icense agreement carefuly 


The Setup Wizard wll nstal PHP 5.3.2 on your computer, 
Chck Next to continue or Cancel to ex the Setup Wizard 


Pease disable any vrus detection software you may have The PHP License, version 3.01 


running during th installation. Icopyright (c) 1999 - 2009 The PHP Group. All rights 
忆 


Redistribution and use in source and binary formay 
ith or without 
modification, is permitted provided that the 加 


(accept the terms n the Lcense Agreemert] 
ce | 


图 1-12 PHP 安装 程序 欢迎 界面 图 1-13 PHP 用 户 安装 许可 协议 
[rrsazs 


Destination Folder Choose Items to Install 
Chck Next to install to the defauk Folder or cick Browse to choose another 3 Select the way you want features to be installed. 


Install PHP 53.2tor Chck the cons In the tree below to change the way Features wil be Installed. 


Se Optional Extras for the PHP Install | 


Per BX) Srpt Exectable 
s | Eterson: 
Browse,,, [x -Be 


SE Entire feature will be installed on local hard drive 


XEntire feature will be unavailable 


图 1-14 PHP 安装 路 径 选 择 图 1-15 PHP 安装 路 径 选择 
单 击 图 1-15 中 的 Next 按钮 继续 安装 ， 直 至 出 现 如 图 1-16 所 示 的 界面 。 单 击 Finish 按 
钮 ， 完 成 整个 安装 过 程 。 
Completed the PHP 5,3.2 Setup Wizard 


Chck the Finish button to ex the Setup Wizard， 


图 1-16 结束 PHP 5.3.2 的 安装 


接 下 来 的 工作 就 是 配置 PHP。PHP 的 配置 选项 保存 在 文件 php.ini 中 , 该 文件 称 为 PHP 
配置 文件 。 配 置 PHP 可 以 通过 编辑 文件 php.ini 来 实现 ， 其 步骤 如 下 
(1) 在 PHP 安装 目录 中 找到 php.ini 文件 , 并 将 其 复制 到 Apache 安装 目录 下 的 Apache2.2 
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文件 夹 中 。 
(2) 用 “记事 本 ”程序 打开 php.ini 文件 。 
(3) 设 置 动 态 模块 的 加 载 路 径 。, 执 行 “编辑 ”一 “查找 ”命令 , 在 文件 中 找到 extension_dir 
选项 ， 由 于 PHP 的 安装 目录 是 E:\php5， 故 在 此 设置 为 : 
extension_dir = "E:\PHPS\ext" 


(4) 用 同样 的 方法 找到 doc_root 选 项 ,设置 PHP 文 档 的 根 目录 ,建议 该 根 目录 与 Apahce 
的 DocumentRoot 命令 中 配置 的 网 站 主 目录 保持 一 致 ， 即 设置 为 同一 
(5) 设置 保存 会 话 信息 的 目录 。 该 选项 的 原始 设置 为 : 


;Session.save_path = "/tmp" 


根据 用 户 实际 安装 情况 ， 正 确 输入 目录 路 径 后 ， 将 语句 前 面 的 “;” 符 号 去 掉 ， 使 设置 
生效 。 因 为 “;” 符 号 在 php.ini 文件 中 表示 该 行 的 语句 是 注释 语句 ， 而 非 执行 语 各 
(6) 设置 错误 信息 显示 选项 。 在 文件 中 找到 display_errors， 然 后 将 其 设置 为 : 


display_errors = On 


则 在 执行 PHP 程序 时 ， 如 遇 到 错误 ， 将 显示 错误 信息 。 
(7) 设置 服务 器 默认 时 区 。date .timezone= PRC， 表 示 把 该 项 的 值 设 为 中 国 的 标准 时 间 。 


1.3.4 PHP 与 Apache 建立 关联 


虽然 Apache 已 经 可 以 正常 运行 了 ， 但 此 时 服务 器 仍 无 法 运行 PHP 网 页 。 要 想 让 服务 
器 能 运行 PHP 网 页 ， 必 须 使 PHP 与 Apache 建立 关联 ， 且 该 关联 操作 必须 在 确保 前 期 的 准 
备 工作 正确 无 误 地 完成 后 才能 开始 实施 。 其 步骤 如 下 : 

(1) 找到 Apache 配置 文件 并 进行 相应 的 配置 。 

Apache 的 配置 是 通过 修改 httpd.conf 文件 实现 的 。httpd.conf 是 一 个 纯 文本 文件 ， 可 通 
过 “记事 本 ”程序 打开 进行 编辑 。 单 击 “ 开 始 ” 菜 单 ， 选 择 Apache HTTP Server 2.2 一 
Configure Apache Server 一 Edit the Apache httpd. conf Configuration File 命令 ， 即 可 打开 
httpd.conf 配置 文件 。 轩 Mtpd conf - 记事 本 


文件 下) 编辑 于)】 格式 人 0) 查看 WW 秋 助 0D 


(2) 通过 下 面 两 种 方式 ， 可 实现 configuration directives that give the server its 


instructions. 


PHP 与 5 Apache 的 关联 。 # See <URL:http://httpd.apache.org/docs/2.2> For detailed 


information- 


(全 使 用 CGI 二 进 制 文件 方式 。 此 Scripthlias /phptext/ “e:/phl 


Action application/x-httpd-| el “e:/php5/php-cgi .exe” 


时 需要 把 以 下 代码 添加 到 httpd.conf 文 
件 中 ， 如 图 1-17 所 示 。 图 1-17 配置 httpd.conf 文 件 


ScriptAlias /phptext/ "e:/php5/” 
AddType application/x-httpd-php .php 
Action application/x-httpd-php "e:/phpS/php-cgi.exe”" 


其 中 ，e:/php5 表示 PHP 的 安装 路 径 ， 读 者 可 以 根据 自己 的 PHP 安装 路 径 来 进行 设置 。 
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@ 使 用 DLL 动态 连接 模块 方式 。 此 时 需要 把 以 下 代码 添加 到 httpd.conf 文件 中 。 


PHPIniDir "e:/php5/” 
AddType application/x-httpd-php .php 
LoadModule php5_module "e:/php5/php5apache2_2.dIl" 


以 上 配置 信息 正确 输入 并 保存 后 ， 重 新 启动 Apache 服务 器 使 其 生效 。 


< 他 注意 : 在 httpd.conf 文件 中 输入 配置 语句 时 ， 行 首 不 能 有 “#” 号 ， 否 则 将 会 被 作为 注 
释 语句 而 失去 作用 。 


1.3.5 测试 PHP 运行 环境 


在 PHP 中 可 通过 phpinfo0 函 数 查 看 服务 器 的 运行 环境 ， 包 括 PHP 的 编译 选项 及 扩充 
配置 、PHP 版 本 、 服 务 器 信息 及 环境 变量 、PHP 环境 变量 以 及 操作 系统 的 版 本 信息 等 。 
打开 Windows 记事 本 程序 ， 在 文本 编辑 区 中 输入 如 下 代码 : 


<html> 

<head> 

</head> 

<body> 

<?php 

echo phpinfo(); 

?> 

</body> 

</html> 

然后 保存 文件 为 test.php 文件 ， 保 存 类 型 应 选择 “所 有 文件 ”， 保 存 路 径 为 Apache 网 
站 主 日 录 。 最 后 ， 在 下 浏览 器 中 输入 http://localhost/text.php， 并 按 Enter 键 ， 即 可 浏览 如 
图 1-18 所 示 的 PHP 运行 环境 测试 信息 。 

友和 旭 四国 的 记 虹 认命 全 -部 辐 : 


地 li9) | 图 Wpiocahosthest otp 


Apache Environment 


七 
han 
ob dbtate 


[FTTTT MEIE 6.0; Wndows NT 5.1; SVL NET CR 
1.1.4322; NET CIR 20.50727) 


ocahest 
Keso-Ahe 


WINDOWS system32 CAWINDOWS: GUMINDOWS\Systemna2 
wbom;c:IProgram FiesiMaozoft SQL Sarver\B0\TooENBINN; C:\Program 
iesicommon Pestrhurder NetwattWankantcodecs 


图 1-18 PHP 运行 环境 的 测试 
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1.4 常用 的 PHP 程序 编辑 工具 


编写 PHP 程序 的 工具 很 多 ， 常 用 的 网 页 编辑 器 如 FrontPage、Dreamweaver， 常 用 的 文 
本 编辑 器 如 Word、UltraEdit、Windows 记事 本 都 可 以 用 来 编辑 PHP 源 代 码 ， 当 然 ， 还 有 
专门 的 PHP 开发 工具 ， 如 Zend Studio 等 。 


1.4.1 PHP 代码 开发 工具 


常见 的 PHP 代码 开发 工具 有 若干 种 ， 由 于 篇 幅 有 限 ， 在 这 里 只 介绍 功能 最 强 的 两 种 : 
Zend Studio 和 DzSoft PHP Editer。Zend Studio 是 最 为 优秀 的 PHP 程序 开发 工具 ,其 最 新 版 
本 是 Zend Studio 7.1.1。Zend Studio 是 Zend Technologies 开发 的 PHP 语言 集成 开发 环境 
(Integrated Development Environment，IDE) ， 它 同时 也 支持 HTML 和 JavaScript 语言 ， 
但 只 对 PHP 语言 提供 调试 支持 。Zend Studio 7.1.1 具备 功能 强大 的 专业 编辑 工具 和 调试 工 
具 ， 支 持 PHP 语法 加 亮 显 示 ， 支 持 语法 自动 填充 与 提示 功能 ， 支 持 书签 、 语 法 自动 缩 排 和 
复制 功能 ，Zend Studio 7.1.1 内 置 一 个 强大 的 PHP 代码 调试 工具 ， 它 可 以 在 本 地 和 远 
程 两 种 调试 模式 下 进行 程序 调试 ， 其 界面 如 图 1-19 所 示 。 


PHP Dprooran FesWpache Group Apache Zt oc ravelwan Php Zend Stodio mm™ 
Ele Edt Source Refactor Navigate Seg 中 Project Run Wndow Hep 
:站 切 " 0'Q-%， 失信 巴 自 尹 - 四 | 画 pp 
B@ 已 GO 和 
ER [下 国 中 加 manphp 》 EA 
1 return false; a = EE 
-| 加 区 
一 有 日 和 esiks 自 
多 | y 日 gine 日 
a 1 
4 区 pojedtl 2 a © $row 四 
de eK frescont | 风 
加 projedtl 19 include{'Clasa\C p'); sn 6 
吕 PHP Language Li 本 2 4pageNo 局 
4cace = neg Category ofpogeCont 
$results = $cate-: >GetCategorylist (); $pageCounk 
人 
le border="0" cellspacing="3" width="712" alig: o 0 
和 © gresuksl 
td colspan="5" width="700" height="102" <imy 6 growl 
< 4 外 
a -ls ， 
图 1-19 Zend Studio 软件 界面 
~ 去 / ey EY 
DzSoft PHP Editer 是 一 款 Windows 下 优秀 的 PHP 脚本 集成 开发 环境 。 该 软件 是 专 为 


PHP 设计 的 网 页 程序 编辑 软件 ， 具 有 对 PHP 程序 进行 编辑 、 侦 错 、 浏 览 、 源 代码 检视 、 档 
案 浏览 、 可 自 订 的 原始 码 样 本 等 功能 。 与 Zend Studio 不 同 的 是 ，DzSoft PHP Editer 无 须 架 
设 网 站 服务 器 环境 就 可 以 测试 由 PHP 指令 码 组 成 的 PHP 程序 ， 总 之 ， 它 是 一 套 功能 强大 
的 PHP 编程 软件 ， 其 工作 界面 如 图 1-20 所 示 。 
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DrSoft PHP Editor 4.EE 
Pile Edit Search 内 er Ran Boolmarks Heslp Check for Vpdates 


GD-B-IBB lt + m0 Paoeiborirr |” 


图 1-20 ”DzSoft PHP Editer 软件 界面 
1.4.2 ”网 页 设计 工具 


常用 的 网 页 设计 工具 软件 包括 FrontPage 和 Dreamweaver 两 种 ， 二 者 都 可 以 用 于 编辑 
PHP 程序 ， 在 这 里 只 介绍 最 为 流行 的 Dreamweaver 软件 。 作 为 网 页 设计 三 剑客 之 一 的 
Dreamweaver, 已 经 占据 了 网 站 设计 与 开发 的 多 数 市 场 份额 , 用 它 可 以 轻而易举 地 制作 出 跨 
越 平 台 限 制 和 跨越 浏览 器 限制 的 充满 动感 的 网 页 ， 本 书 将 在 第 10 章 中 详细 介绍 利用 
Dreamweaver 开发 PHP 动态 网 站 的 方法 。Dreamweaver 的 工作 界面 如 图 1-21 所 示 。 


ee Dende tine peehe? 2Nh120700 50 717 
E77 


图 1-21 Dreamweaver 软件 界面 


1.4.3 文本 编辑 工具 


在 这 里 只 介绍 一 种 最 常见 的 文本 工具 ， 即 Windows 自 带 的 文本 编辑 工具 NotePad〈 记 
事 本 ) 。 记 事 本 占用 内 存 极 少 ， 运 行 速度 极 快 ， 但 功能 较 简单 。 在 使 用 记事 本 编写 好 程序 
存盘 的 时 候 应 注意 ， 在 “文件 名 ”文本 框 中 手动 输入 文件 名 时 ， 扩 展 名 为 “php”， 保 存 
类 型 应 选择 “所 有 文件 ”， 如 图 1-22 所 示 。 
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图 1-22 用 记事 本 编写 PHP 代码 并 存储 


1.5 本 章 小 结 


本 章 首先 介绍 了 Web 的 基本 概念 ， 接 着 介绍 了 PHP 的 概念 、 基 本 原理 及 其 产生 与 发 
展 过 程 ， 其 中 重点 介绍 了 Apache 服务 器 的 安装 与 配置 、PHP 的 安装 与 配置 以 及 PHP 与 
Apache 的 关联 等 ， 最 后 介绍 了 PHP 程序 常用 的 编写 工具 。 


1.6 练习 题 


1. 简 述 PHP 的 概念 及 其 发 展 历程 。 
2. 简 述 PHP 的 特点 。 它 与 其 他 脚本 语言 有 何 区 别 ? 
3. 举例 说 明 如 何 实现 PHP 与 Apache 的 关联 。 


17 上 机 实战 


要 求 读者 根据 本 章 所 讲 知识 ， 试 着 将 自己 当前 使 用 的 计算 机 配置 为 PHP 动态 网 站 开发 
所 需 的 环境 ， 其 步骤 如 下 : 
(1) 从 Apache 官方 网 站 上 下 载 较 新 版 本 的 Apache 安装 程序 到 本 地 机 , 然后 在 本 地 机 
上 进行 安装 ， 同 时 正确 配置 服务 器 。 
< 注意 : 要 选择 Windows 安装 版 。 


(2) 下 载 合 适 版 本 的 PHP 安装 程序 (选择 Windows 安装 版 ) ， 然 后 进行 安装 。 
(3) 通过 对 Apache 和 PHP 进行 相关 的 配置 ， 实 现 PHP 与 Apache 的 关联 。 
(4) 在 HIML 标记 语言 的 BODY 标记 部 分 嵌入 代码 : 

<?php 


echo phpinfo() 
于 六 


以 测试 PHP 程序 开发 环境 是 否 组 建成 功 并 查看 相关 配置 信息 。 


第 2 章 HTML 基础 


知识 点 : 


HTML 文档 的 基本 结构 
主要 文本 格式 标记 

超 链接 标记 

图 像 标记 

表格 标记 

表单 标记 

在 HTML 中 使 用 PHP 代码 


本 章 导读 ; 


PHP 是 一 种 嵌入 在 HIML 代码 中 的 脚本 语言 ， 它 必须 依赖 于 HTML 才能 存在 。PHP 程 
序 在 服务 器 端 执行 ， 并 将 程序 运行 结果 以 HTML 的 形式 连同 其 他 的 HTML 一 起 发 送 给 客 
户 端 ， 客 户 端 用 户 再 通过 浏览 器 查看 自己 想 要 看 到 的 信息 。 在 学 习 PHP 语言 之 前 ， 有 必要 
先 介绍 一 下 HTML 基础 知识 ， 其 中 包括 HTML 文档 的 基本 结构 、 各 种 文本 格式 标记 、 超 
链接 标记 以 及 表格 标记 等 HTML 中 主要 标记 的 使 用 方法 ， 以 便 使 广大 读者 尤其 是 初学 者 更 
容易 理解 本 书后 面 章节 的 内 容 。 


加 罗网 罗网 网 同 


2.1 HTML 文档 的 基本 结构 


HTML 不 像 C、Basic 之 类 的 程序 设计 语言 ， 它 只 是 标记 语言 ， 基 本 上 只 要 明白 了 各 种 
标记 的 用 法 和 含义 就 算 学 懂 了 HTML。HTML 的 任何 标记 都 由 “<” 和 “>” 括 起 来 ， 如 
<html><i>。 标 记 有 单 标记 和 双 标 记 之 分 ， 超 文本 标记 一 般 成 对 出 现在 文本 中 。 双 标记 由 
始 标记 和 尾 标 记 两 部 分 组 成 ， 在 其 中 间 可 以 放 入 要 修饰 或 说 明 的 各 种 内 容 ， 用 带 “/” 的 
元 素 表示 结束 ， 如 <html> 和 </html>。 只 有 始 标记 而 没有 尾 标记 的 称 为 单 标记 ， 如 <br>， 
表示 在 网 页 中 引入 一 个 换行 符 。 标 记 的 作用 只 是 改变 网 页 显示 方式 ， 其 本 身 不 在 浏览 
中 显示 。 


2.1.1 HTML 文件 结构 


一 个 标准 的 HTML 文件 通常 由 4 个 主要 的 标记 元 素 构 成 ， 其 基本 格式 如 下 : 


<html> 


<head> i 
<title>HTML 文件 标题 </title > | 六 件 寺 
</head> 
<body> HTML 文件 
html 文件 的 正文 写 在 这 里 .… 
<body> | 文件 体 
</html> 


其 中 , <html></html> 在 最 外 层 , 用 以 表示 这 对 标记 间 的 内 容 是 HIML 文档 。<html></html> 
标记 有 时 会 被 省 略 ， 这 是 因为 .html 或 .htm 文件 已 被 Web 浏览 器 默认 为 是 HTML 文档 。 
<head></head> 之 间 包 括 文档 的 头 部 信息 , 如 文档 总 标题 等 , 若 在 实际 应 用 中 不 需要 此 信息 ， 
可 省 略 此 标记 。<body> 标 记 一 般 不 能 省 略 ， 表 示 正 文 内 容 的 开始 。 


2.1.2 ”标题 标记 及 主体 标记 
标题 标记 <title>…</title> 用 于 定义 页 面 的 标题 ， 在 浏览 网 页 时 其 定义 的 文本 内 容 将 显 
示 在 浏览 器 的 标题 栏 中 。 主体 标记 <body>…</body> 用 来 指明 文档 的 主体 区 域 , 网 页 要 显示 


的 信息 都 包括 在 这 对 标记 中 ， 其 中 ，<body> 标 记 表示 主体 区 域 的 开始 位 置 ，</body> 标 记 表 
示 主 体 区 域 的 结束 位 置 。 


2.2 文本 格式 标记 


在 HTML 中 ,利用 文本 标记 可 以 让 文本 和 图 像 显示 的 更 整齐 、 美 观 和 有 序 。 本 节 主 要 
介绍 一 些 常用 的 文本 格式 标记 及 其 属性 ， 学 习 后 ， 读 者 可 以 掌握 如 何在 网 页 中 合理 使 用 文 
本 ， 并 根据 需要 选择 不 同 的 显示 效果 。 


2.2.1 标题 字体 标记 


标题 字体 标记 <hn></hn> 是 具有 语义 的 标记 ， 它 指定 浏览 器 在 该 标记 对 中 显示 一 个 标 
题 ， 字 体 为 黑色 粗 体 。 该 标记 可 以 用 来 定义 第 n 号 标题 ， 其 中 n=1、2、3、4、5、6。n 的 
值 越 大 ， 字 越 小 ，<h1> 是 最 大 的 标题 标记 ， 而 <h6> 是 最 小 的 标题 标记 。 标 题 标 记 有 一 个 常 
用 的 属性 ， 即 align， 它 可 以 设置 该 标记 元 素 的 内 容 在 一 行 空间 内 的 对 齐 方式 ，left 表示 左 
对 齐 ，right 表示 右 对 齐 ，center 表示 居中 对 齐 。 例 如 : 

<h1> align ="center" 本 段 文字 居中 对 齐 ! 

</h1> 表 示 “ 本 段 文字 居中 对 齐 ! ”这 一 文本 以 一 级 标题 格式 ， 并 按 居 中 对 齐 的 方式 显 
示 在 网 页 上 。 


2.2.2 字体 风格 标记 


字体 风格 标记 <b><i><u><sup><sub><em><strong><big> 主 要 用 来 对 文字 加 粗 、 倾 斜 和 
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加 下 划 线 等 。 字 体 风 格 标记 可 以 给 普通 的 文本 增添 丰富 的 视觉 效果 ， 主 要 由 以 下 标记 来 组 成 。 
口 <b>: 表示 粗 体 。 例 如 ,“<b> 今 天 天 气 真 好 ! </b>” 将 在 网 页 上 显示 粗 体 文本 “ 今 
天 天 气 真 好 !”。 

<i>: 表示 和 斜体。 

<u>: 表示 在 文字 下 面 加 下 划 线 。 

<sup>: 表示 将 文字 上 调 半 行 。 

<sub>: 表示 将 文字 下 调 半 行 。 例 如 ，H<sub>2</sub>O， 将 在 浏览 器 中 显示 H2O; 
Y<sup>2<sup>， 在 浏览 器 只 能 够 显示 Y?。 

口 <em>: 表示 突出 显示 所 定义 范围 内 的 文字 。 例 如 ，<em> 这 是 重点 内 容 </em>。 
口 “<strong>: 表示 强调 所 定义 范围 内 的 文字 。 例如 ，<strong> 这 是 重点 内 容 </strong>。 
口 “<big>: 表示 大 字体 。 例 如 ，“<big> 中 国 </big>” 将 在 浏览 器 窗口 中 显示 大 字体 的 
“中 国 ” 两 个 字 。 


2.2.3 ”字体 标记 


利用 字体 标记 <font></fonf> 可 以 改变 文字 的 字体 、 字 号 和 颜色 , 主要 是 通过 对 face、 size 
和 color 3 个 属性 的 不 同 设 置 来 实现 的 。 例 如 : 

<font face=" 华 文 宋体 "size="5" color="#000099"></font> 

其 中 ，face 用 来 定义 文字 的 字体 ，size 用 来 定义 字号 大 小 ，color 用 来 定义 文本 颜色 。 
定义 颜色 时 ， 可 以 用 十 六 进 制 数 来 表示 某 种 颜色 ， 如 “#000099”; 也 可 以 用 black、olive、 
teal、 red、 blue、 maroon、 navy、 gray、 lime、 fuchsia、 white、 green、purple、silver、yellow、 
aqua 等 预定 义 色彩 来 表示 。 例 如 ， 要 在 网 页 上 显示 白色 字体 ， 可 以 定义 为 : <font 
color="#ffffff'> 白 色 字 体 </font>， 也 可 以 是 : <font color=white> 白 色 字 体 </font>。 这 两 条 语 
句 的 功能 完全 一 样 ， 只 是 使 用 的 方法 不 同 。 
2.2.4 字段 落 标记 与 换行 标记 

在 网 页 中 显示 多 行文 本 时 ， 往 往 要 根据 内 容 进 行 分 段 或 换行 。 在 HIML 中 ， 分 段 和 换 
行 的 标记 分 别 是 段 标记 <p></p> 和 换行 标记 <br>。 

1. 段 (Paragraph) 标记 <p></p> 

该 标记 的 作用 是 在 其 所 在 位 置 对 文本 进行 分 段 。 例 如 , 在 HTML 文件 的 文件 体 部 分 加 
入 代码 “你 好 吗 ? <p> 很 好 </p>”， 其 网 页 效果 如 图 2-1 所 示 。 
< 注意 : 在 两 行文 字 之 间 空 了 一 行 。 

2. 换行 标记 <br> 

该 标记 的 作用 是 在 其 所 在 位 置 进行 强制 换行 。 同 样 ， 在 HTML 文件 的 文件 体 部 分 加 入 
代码 “你 好 吗 ? <br> 很 好 ”， 其 网 页 效果 如 图 2-2 所 示 。 请 仔细 区 分 图 2-1 与 图 2-2 中 网 页 
的 差别 。 
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您 好 四 ? 
你 好 吗 ? 良好 。 


图 2-1 <p></p> 标 记 的 应 用 图 2-2 <br> 标 记 的 应 用 


2.2.5 ”列表 标记 


为 了 合理 地 组 织 文本 或 其 他 对 象 ， 网 页 中 常常 要 用 到 列表 。 在 HTML 中， 可 以 使 用 的 
列表 标记 包括 无 序列 表 标 记 <ul></ul>、 有 序列 表 标 记 <ol></ol> 以 及 自 定义 列表 标记 
<dl></dl> 3 种 ， 每 个 列表 都 包含 若干 个 列表 项 。 

无 序列 表 标 记 的 语法 为 ，<ul><li>…</ml>。 例 如 : 


<ul> 
<li>Today 
<li>Tommorow 
</ul> 


有 序列 表 标 记 的 语法 为 ，<ol><li>…</ol>。 例 如 : 


<ol> 
<li>Today 
<li>Tommorow 
</ol> 


两 种 列表 标记 使 用 效果 的 差别 如 图 2.3 所 示 。 
[ 证 


EE -© awPan 


| lw (Eo. snr 


地址 | tw ee VDocmments and Settines\Adnir 
1. Today 


。Today 2. Tommorow 
® Tommorow 


ll EL 


EEE 4 EE 
(a) 无 序列 表 标 记 的 应 用 Cb) 有 序列 表 标 记 的 应 用 


图 2-3 无 序列 表 与 有 序列 表 标记 的 使 用 效果 
自 定义 列表 标记 的 语法 为 :<dl><dt></dt><dd></dd></dl>。 其 中 ，<dl></d> 是 自 定义 
列表 的 起 止 标记 , <dt></dt> 用 于 定义 自 定义 列表 的 标题 , <dd></dd> 用 于 定义 列表 中 的 具体 
各 项 。 例 如 : 


<dl> 
<dt> 湖 南城 市 </dt> 
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<dd> 长 沙 </dd> 
<dd> 衡 阳 </dd> 
<dd> 常 德 </dd> 

</dl> 

<dl> 

<dt> 湖 北城 市 </dt> 

<dd> 武 汉 </dd> 
<dd> 误 樊 </dd> 
<dd> 宜 昌 </dd> 

</dl> 


网 页 实际 的 运行 效果 如 图 2-4 所 示 。 


C \Docanents and Settings\la\ 点 面 \ww htsl ”Windor> J 
PC 
> ec voments wa :Hl x) 5 


文件 中 编辑 四 可 看 WD 收藏 严 @) 工具 加 ) 帮助 00 


训 收 天国 | -| 的 RW [ecweeeu ous... x | 


图 2-4 列表 标记 的 举例 


2.2.6 水平线 标记 
水 平 线 标记 <hr/> 是 一 个 很 单一 的 标记 ， 用 来 在 网 页 中 插入 一 条 水 平 线 。 例 如 : 


<hr size="3" width="85%" noshade="noshade" /> 


其 中 ，size 用 来 设置 水 平 线 的 粗细 ; noshade 用 来 设置 水 平 线 是 否 具 有 阴影 效果 ， 其 默 
认 值 为 noshade， 即 没有 阴影 效果 。 


2.2.7 ” 转 义 字符 与 其 他 特殊 符号 


在 HTML 代码 中 , 文本 中 的 有 些 符 号 (如 空格 、 大 于 号 等 ) 是 不 会 显示 在 浏览 器 中 的 。 
因此 ， 在 需要 显示 它们 的 时 候 ， 就 必须 在 源 代码 中 输入 它们 对 应 的 特殊 字符 。 这 些 特殊 字 
符 可 以 分 为 3 类 。 

1. 特殊 字符 

有 些 符号 是 无 法 用 键盘 直接 输入 的 ,因此 需要 在 HIML 源 代码 中 用 特殊 的 字符 来 表示 ， 
如 版 权 符号 D， 需 要 在 源 代码 中 用 “&copy:” 来 代替 ， 还 有 如 “ 土 ” 用 “&plusmn;” 来 代 
替 ，“ 二 ”用 “&divide” 来 代替 ，“%o” 用 “&#8240” 来 代替 等 。 
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2. 转 义 字符 

由 于 在 HTML 标记 中 已 经 使 用 了 大 于 号 和 小 于 号 ,因此 在 HIML 代码 中 若 再 出 现 “>”、 
“<”， 就 会 被 认为 是 普通 的 大 于 号 或 小 于 号 。 如 果 要 显示 “5>3” 这 样 一 个 不 等 式 ， 则 需 
要 用 “&gt;” 代 表 符号 “>”， 用 “&lt;” 代 表 符 号 “<” 来 实现 。 例 如 : 


<p>a&gtib&divide;3</p> <L-- 在 浏览 器 中 显示 “a>b 二 3”--> 
<p>a&ilt;|&plusmn;b|</p> <!-- 在 浏览 器 中 显示 “a<| 土 x|”--> 
<p align="center"> 网 站 版 权 所 有 者 &copy; 公司 </p> <!-- 在 浏览 器 中 显示 版 权 信 息 --> 


< 注意 ; 在 上 述 语句 的 末尾 处 有 <!--***-->， 它 是 HTML 代码 的 注释 语句 ,浏览 器 不 会 执 
行 这 些 语句。 
3. 空格 符号 
在 HIML 代码 中 ， 文 字 与 文字 之 间 只 允许 空 一 个 空格 。 如 果 超 过 一 个 空格 ， 那 么 从 第 
二 个 空格 开始 ， 之 后 所 有 的 空格 都 会 被 忽略 掉 。 如 果 需 要 在 某 处 使 用 多 个 空格 ， 就 需要 使 
用 代表 空格 的 特殊 符号 “&nbsp;” 来 代替 。 一 个 “&nbsp;” 代 表 一 个 半角 的 空格 ， 如 果 输 
入 多 个 空格 ， 可 以 多 次 输入 “&nbsp;”。 


2.3” 超 链接 标记 

链接 是 网 页 最 主要 的 特点 ， 也 是 非常 重要 的 工具 。 用 户 之 所 以 能 通过 互联 网 方便 地 浏 
览 大 量 的 信息 资源 ， 原 因 就 在 于 网 站 的 网 页 中 存在 着 大 量 的 超 链接 。 
2.3.1 链接 的 定义 

链接 的 源 对 象 是 指 可 以 设置 链接 的 网 页 对 象 , 主要 有 文本 、 图 像 或 文本 图 像 的 混合 体 。 
它们 对 应 <a> 标 记 所 显示 的 内 容 。 其 语法 格式 如 下 : 

<a hre 人 "url" title = "鼠标 悬 停 在 超 链 接 上 时 显示 的 文字 注释 "> 链接 显示 内 容 </a> 

其 中 ，href 用 来 指定 这 个 链接 所 要 打开 的 文件 路 径 ， title 用 来 让 鼠标 悬 停 在 超 链接 上 


时 ， 显 示 该 超 链接 的 文字 注释 。 链 接 显示 内 容 可 以 是 普通 文本 ， 也 可 以 是 一 副 图 片 或 图 片 
与 文字 的 混合 


2.3.2 ” 超 链接 的 种 类 


网 页 中 超 链接 的 种 类 有 很 多 ， 如 文件 链接 、 电 子 邮件 链接 、 锚 链接 等 。 定 义 不 同 链接 
时 ， 只 需要 将 href 属性 设置 为 相应 的 内 容 即 可 。 

1. 文件 链接 

文件 链接 是 指 链接 到 其 他 网 页 或 文件 。 定 义 文件 链接 的 方法 如 下 。 
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口 ”外 部 链接 : <a hre 全 "http:/www.cec.edu.cm/index html"> 某 学 院 校园 网 首页 </a> 
口 ” 内 部 链接 : <a hre 全 "index.html"> 返 回 到 首页 </a> 
口 下 载 链 接 : <a href-"documentword 文档 .doc"> 单 击 下载 </a> 


2. 电子 邮件 链接 


网 站 中 ， 经 常会 看 到 标注 “联系 我 们 ”字样 的 超 链 接 。 单 击 这 个 超 链接 ， 就 会 触发 邮 
件 客户 端 ， 如 触发 Outlook Express 程序 ， 然 后 显示 一 个 新 建 E-mail 的 窗口 。 用 <a> 可 以 实 
现 这 样 的 功能 : 

<a href = "mailto:mailzjld@cec.edu.cn> 联 系 我 们 </a> 


3. 锚 链接 
当 网 页 内 容 很 长 ， 需 要 进行 页 内 跳 转 链接 时 ， 就 需要 定义 锚 点 和 锚 点 链接 ， 锚 点 可 以 
使 用 name 属性 或 id 属性 定义 。 如 : 


<a name="C1"> 第 一 章 </a> <-- 定 义 锚 点 -> 
<a href="#C1"> 参 见 第 一 章 </a> ”<-- 页 内 跳 转 链接 ， 链 接 到 锚 点 第 一 章 处 --> 


2.4 图 像 标记 


网 页 中 ， 图 像 可 以 更 直接 地 表现 主题 ， 和 凭借 图 像 的 意境 使 浏览 者 印象 深刻 。 用 标记 
<img> 可 以 在 HTML 里 面 插 入 一 张 图 片 ， 其 基本 语法 格式 如 下 : 
<img src="url"> 
其 中 ，url 表示 图 片 的 路 径 和 文件 名 。 如 url 可 以 是 "images/logo/blabla_ logo01.gif'， 也 
可 以 是 一 个 相对 路 径 ， 如 "../images/logo/blabla_logo01.gif"。 


2.4.1 图 像 的 基本 格式 


网 页 中 的 图 像 文 件 可 以 是 JPG 格式 、GIF 格式 或 PNG 格式 ， 它 们 都 是 压缩 形式 的 图 像 
格式 , 体积 比 位 图 格式 的 图 像 小 ， 比 较 适合 于 网 络 传输 。 下 面 分 别 简单 介绍 这 3 种 图 像 格式 。 


1. GIF 图 片 


GIF (Graphics Interchange Format) 图 片 的 扩展 名 是 .gif。 现 在 所 有 的 图 形 浏览 器 都 支 
持 GIF 格式 ， 有 的 图 形 浏览 器 只 能 识别 GIF 格式 。GIF 是 一 种 索引 颜色 格式 ， 在 颜色 数 很 
少 的 情况 下 ， 产 生 的 文件 极 小 ， 它 的 优点 主要 有 : 
口 支持 透明 背景 。 如 果 GIF 图 片 背 景色 设置 为 透明 ， 它 将 与 浏览 器 背景 合 ， 生 
成 非 矩形 的 图 片 。 
口 ”支持 动画 。 在 Flash 动画 出 现 之 前 ，GIF 动画 可 以 说 是 网 页 中 唯一 的 动画 形式 。 
GIF 格式 可 以 将 单 帧 的 图 像 组 合 起 来 ， 然 后 轮流 播放 每 一 帧 而 成 为 动画 
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口 “支持 图 形 渐进 。 渐 进 即 图 片 渐渐 显示 在 屏幕 上 ， 渐 进 图 片 将 比 非 渐进 图 片 更 快 地 

显示 在 屏幕 上 ， 可 以 让 访问 者 更 快 地 知道 图 片 的 概貌 。 

口 “支持 无 损 压 缩 。 无 损 压 缩 是 不 损失 图 片 细节 而 压缩 图 片 的 有 效 方法 ， 由 于 GIF 格 
式 采 用 无 损 压 缩 ， 所 以 它 更 适合 于 线条 、 图 标 和 图 纸 。 

当然 ，GIF 格式 的 缺点 同样 相当 明显 : 它 只 有 256 种 颜色 ， 这 对 于 要 求 高 质量 的 图 片 

显然 是 不 够 的 。 


2. JPG 图 片 


JPG (Joint Photograhic Experts Group， 联 合 图 像 专家 组 ) 的 优点 是 能 支持 上 百 万 种 颜 
色 ， 可 以 表示 出 自然 界 中 几乎 所 有 的 颜色 。JPG 图 片 使 用 了 有 损 压 缩 算 法 ， 放 弃 了 图 像 中 
的 某 些 细节 ， 因 此 其 文件 较 小 ， 下 载 时 间 较 短 。 而 且 ， 从 浏览 角度 来 讲 ， 图 像 质量 受 损 不 
会 太 大 ， 这 样 就 大 大 提高 了 网 络 传输 和 磁盘 交换 文件 的 速度 。 

但 是 从 长 远 来 看 ，JPG 随 着 带宽 的 不 断 提 高 和 存储 介质 的 发 展 ， 它 也 应 该 是 一 种 被 淘汰 
的 图 片 格式 。 有 损 压 缩 会 对 图 像 产生 不 可 恢复 的 损失 ,所 以 经 过 压缩 的 PG 图 片 一 般 不 适合 
打印 。 另 外 ,JPG 也 不 像 GIF 图 像 那么 灵活 ， 它 不 支持 图 形 渐进 和 透明 背景 ， 更 不 支持 动画 。 


3. PNG 图 片 


PNG (Portable Network Graphic Format， 流 式 网 络 图 形 格式 ) 是 20 世纪 90 年 代 中 期 
出 现 的 图 像 文 件 存 储 格 式 ， 其 主要 用 于 替代 GIF 和 TIFF 文件 格式 ， 同 时 兼 有 GIF 文件 格 
式 所 不 具备 的 一 些 特性 。PNG 采用 位 图 文件 (Bitmap File) 存储 格式 ， 用 来 存储 灰 度 图 像 
时 ， 灰 度 图 像 的 深度 可 达 16 位 ; 存储 彩色 图 像 时 ， 彩 色 图 像 的 深度 可 达 48 位 。 
在 PNG 格式 的 图 像 文件 中 ， 增 加 了 下 列 GIF 格式 图 像 文件 所 没有 的 特性 : 
每 个 像素 为 48 位 的 真 彩色 图 像 。 
每 个 像素 为 16 位 的 灰 度 图 像 。 
可 为 灰 度 图 和 真 彩色 图 添加 a 通道。 
添加 图 像 的 y 信 息 。 
使 用 循环 元 余 码 检测 损害 的 文件 。 
加 快 图 像 显 示 的 逐次 逼近 显示 方式 。 
标准 的 读 / 写 工具 包 。 


2.4.2 ”图像 的 对 齐 方式 


DOOOODODODODD 


<img> 标 记 的 对 齐 方式 可 以 通过 align 属性 来 设置 ， 其 不 同 的 取 值 一 共有 9 种， 其 中 实 
现 图 片 和 文本 混 排 的 有 “ 左 对 齐 ”、“ 右 对 齐 ” 及 “居中 对 齐 ”。 例 如 : 
<img src = ".../images/html_tutorials/smile.jpg" align="left /> 


此 标记 表示 按照 src 指定 的 路 径 来 引用 名 为 smile.jpg 的 图 片 ， 并 且 按 居中 对 齐 的 方式 


显示 。 


ll 
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2.4.3 图 像 的 大 小 


在 默认 状况 下 ， 图 片 显示 原 有 的 大 小 ， 用 户 可 以 用 height 和 width 属性 改变 图 片 的 大 
小 。 例 如 : 


<img src="Previous.gif’ width="14" height="13" align="left"/> 


不 过 ， 图 片 的 大 小 一 旦 被 改变 ， 图 片 实际 显示 的 尺寸 也 会 发 生 改变 ， 最 终 效果 可 能 会 
很 难看 。 同 时 ， 由 于 图 片 相对 文字 来 说 ， 所 占 的 字 节 数 较 多 ， 如 一 个 全 屏 的 图 片 ， 经 过 压 
缩 后 ， 也 要 占 去 大 约 50KB 的 存储 容量 ， 这 相当 于 一 个 25000 字 纯 文本 文本 的 大 小 ， 所 以 
在 网 页 中 插入 过 多 的 图 像 时 ， 浏 览 网 页 会 变 得 很 慢 ， 一 般 情况 下 ， 建 议 读者 在 一 个 HTML 
文件 中 不 要 包含 过 多 的 图 片 ， 否 则 会 影响 网 页 的 显示 速度 。 


2.5 表格 标记 


表格 在 网 页 中 的 应 用 非常 广泛 ， 可 以 用 来 对 整个 页 面 进行 精心 布局 ， 使 页 面 变 得 井然 
有 序 。 所 以 ， 表 格 的 相关 语法 在 HTML 中 是 非常 重要 的 一 部 分 。 


2.5.1 表格 定义 标记 


使 用 好 表格 可 以 提高 网 页 设计 的 工作 效率 ,下面 简单 来 讲解 一 下 HTML 中 定义 表格 的 
相关 语法 格式 。 

<table> 

<tr> ”<-- 定 义 表 行 --> 

<th> 表 头 内 容 </th> 

<td> 表 格 具 体 单元 格 内 的 数据 </td> <-- 定 义 表格 单元 格 --> 

<td> … </td> 

</tr> <-- 行 定义 结束 --> 

</table> ”<-- 定 义 表格 结束 --> 

将 以 上 代码 加 入 HTML 文档 的 文件 体 并 保存 后 ， 用 下 浏览 器 打开 此 文档 ， 将 在 浏览 
器 窗口 中 显示 如 图 2-5 所 示 的 页 面 。 


当 !TH 文 逢 之 表 冤 标记 效果 演示 ~ WicEaSSEEEEEEE 


| 文件 四 编辑 至) 查看 轨 。 收 京 如 工具 帮助 0D 正 了 


下 A 
| ©- EGP Wm ID- 
| 正本 加 |E] eve htnl 眉目 4 || 固 读 ” 

股票 名 称 | 景 高 价 | 景 低 价 | 收盘 价 

ABCD 57625 |8550 |85o0 

EFGH 10100 |97.50 |10000 

[DEL 56.00 34.50 55.00 

MNOP Too lego ley10 

EE I EL 加 


图 2-5 HTML 文档 中 的 表格 
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1. 设置 表格 边框 格式 

定义 表格 边框 格式 的 语法 格式 为 : < table border=# >。 其 中 ，“#?” 为 整数 ， 用 于 设置 
表格 的 边框 大 小 ， 它 以 像素 为 单位 。 下 面 仍 以 图 2-5 中 的 网 页 为 例 来 讲解 表格 边框 的 设置 。 

下 面 的 代码 将 创建 一 个 边框 为 12 像素 的 表格 。 


<table border=12 cellspacing=1 cellpadding=2 width="80%"> 
<thead > 

<tr> <th> 股 票 名 称 </th><th> 最 高 价 </th><th> 最 低 价 </th><th> 收 盘 价 </th> </tr> 
</thead> 

<tr> <td>ABCD</td><td>87.625</td><td>85.50</td><td>85.00</td></tr> 

<tr> <td>EFGH</td><td>101.00</td><td>97.50</td><td>100.00</td></tr> 

<tr> <td>IJKL</td><td>56.00</td><td>54.50</td><td>55.00</td></tr> 

<tr> <td>MNOP</td><td>71.00</td><td>69.00</td><td>69.10</td></tr> 
</table> 


其 中 ，<thead >、</thead> 标 记 和 <th>、</th> 标 记分 别 用 来 定义 表 头 和 表 尾 。 保 存 该 文 
档 后 ， 用 正 浏览 器 打开 此 文档 ， 将 显示 如 图 2-6 所 示 的 页 面 。 


2. 定义 表格 的 长 宽 
设置 表格 长 宽 的 语法 格式 为 : <table border width=# height=#>。 其 中 ，“#” 为 整数 。 
例如 ， 用 下 列 语句 可 以 创建 一 个 高 为 350 像素 、 宽 为 100 像素 的 表格 。 


<table cellspacing=1 cellpadding=2 width="350" height="100" border=1 > 
<tr><td> 公 司 名 称 </td><td> 地 址 </td><td> 签 约 时 间 </td></tr> 
<tr><td>company1</td><td> 四 川 成 都 </td><td> 半 年 </td></tr> 
<tr><td>company2</td><td> 江 苏 南 京 </td><td> 未 签约 </td></tr> 
<tr><td>company3</td><td> 浙 江 杭 州 </td><td>2 年 </td></tr> 
<tr><td>company4</td><td> 广 东 深 圳 </td><td>1 年 </td></tr> 
</table> 


执行 以 上 代码 ， 则 可 在 网 页 中 创建 一 个 如 图 2-7 所 示 的 表格 。 


习 met 文 特 之 表格 标记 效果 演示 ~ icrosvEIEREEE Dx 
E 本 | | | 文件 虽 编辑 中 查看 QD 收藏 人 工具 CI) 天 助 吕 

OO I) [a Cn | me 芝 | EEN EIR 
ES IE | Ew [EE] 6 \ss nl PE 
下 加 


| 股票 名 称 ， 景 高 价 ， 景 低 价 | 收盘 价 公司 名 称 | 地 址 签约 时 间 
ABCD 87.625 |85.50 company1 四 川 成 都 半年 


EFGH 3 company2 江苏 南京 
二 3 company3 ”| 玉江 入 放 
[MNOP 9 company4 | 广东 深圳 


EE 
图 2-6 设置 表格 的 边框 图 2-7 设置 表格 的 长 宽 
通过 这 个 实例 ， 顺 便 讲 述 一 下 关于 设置 表 元 〈 即 单元 格 ) 间 队 和 内 部 间隙 的 语法 ， 其 
格式 为 : <table cellspacing=# ， cellpadding=# >。 同 样 ，“#” 表 示 整 数 。 如 在 本 例 中 ， 编 者 
设计 的 是 <table cellspacing=1 cellpadding=2 >。 
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3. 创建 跨 多 列 的 单元 格 
创建 跨 多 列 单元 格 的 语法 格式 为 : <td colspn= 纹 。 其 中 , “# ”表示 单元 格 所 跨 的 列 数 。 


例如 ， 用 下 列 语句 可 以 建立 一 个 首 行 跨 多 列 的 表格 。 


<table cellspacing=1 cellpadding=2 width="350" height="100" border=1 > 
<tr><td colspan=3> 毕 业 生 就 业 情 况 统计 </td></tr> 
<tr><td> 公 司 名称 </td><td> 地 址 </td><td> 签 约 时 间 </td></tr> 
<tr><td>company1</td><td> 四 川 成 都 </td><td> 半 年 </td></tr> 
<tr><td>company2</td><td> 江 苏 南京 </td><td> 未 签约 </td></tr> 
<tr><td>company3</td><td> 浙 江 杭 州 </td><td>2 年 </td></tr> 
<tr><td>company4</td><td> 广 东 深 圳 </td><td>1 年 </td></tr> 

</table> 


执行 以 上 代码 ， 则 可 在 网 页 中 创建 一 个 如 图 2-8 所 示 的 表格 。 
4. 创建 跨 多 行 的 单元 格 
在 HTML 中 同样 能 创建 跨 多 行 的 单元 格 ， 其 语法 格式 为 : <td rowspan=#>。 其 中 ，“#” 


为 整数 ， 表 示 要 跨 的 行 数 。 例 如 ， 用 以 下 语句 可 以 创建 一 个 既 存 在 跨 多 行 的 单元 格 、 又 存 
在 跨 多 列 的 单元 格 的 表格 。 


中 ， 
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<table cellspacing=1 cellpadding=2 width="350" height="100" border=1 > 
<tr><td colspan=4 align="center"> 毕 业 生 就 业 情况 统计 </td></tr> 
<tr><td> 系 别 </td><td> 公 司 名 称 </td><td> 地 址 </td><td> 签 约 时 间 </td></tr> 
<tr><td rowspan=4> 机 械 系 </td><td>company1</td><td> 四 川 成 都 </td><td> 半 年 
</td></tr> 
<tr><td>company2</td><td> 江 苏 南 京 </td><td> 未 签约 </td></tr> 
<tr><td>company3</td><td> 浙 江 杭 州 </td><td>2 年 </td></tr> 
<tr><td>company4</td><td> 广 东 深 圳 </td><td>1 年 </td></tr> 

</table> 


执行 以 上 代码 ， 则 可 在 网 页 中 创建 一 个 如 图 2-9 所 示 的 表格 。 
当 !TL 文 拓 之 表格 标记 演示 效果 = SEASAEGEEREE 
上 文件 中 编辑 人 E) 查看 WW 收 产 亿 ) 工具 I) 大 


EE 


习 xml 文档 之 表格 标记 演示 效果 WCG 
| 文件 @)， 六 得 E) 查看 WD 尿 宗 Q) 工具 各 助 ( ”| 


Ea 2 
[itwleirveima 本 


毕业 生 就 业 情况 统计 
公司 名 称 [ 匡 的 时 间 系 别 
companyl 二 
company2 3 机 起 系 | 
company3 3 
company4 广东 深圳 ] 年 
| 

3 [EE 27 

图 2-8 设置 跨 多 列 的 单元 格 图 2-9 设置 跨 多 行 的 单元 格 


5. 设置 表格 的 标题 


表格 的 标题 表明 整个 表格 的 主题 ， 其 语法 格式 为 : <caption align=#>…</caption>。 其 
“#” 可 以 是 left、center、right、top 和 bottom。 例 如 ， 通 过 下 列 语句 可 以 创建 一 个 带 
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标题 的 表格 。 


<table cellspacing=1 cellpadding=2 width=300 height="100" border=1 align= center > 
<caption align="center">【 毕 业 生 就 业 情 况 统计 】<<caption> 
<tr><td> 系 别 </td><td> 公 司 名 称 </td><td> 地 址 </td><td> 签 约 时间 </td></tr> 
<tr><td rowspan=4> 机 械 系 </td><td>company1</td><td> 四 川 成 都 </td><td> 半 年 
</td></tr> 
<tr><td>company2</td><td> 江 苏 南京 </td><td> 未 签约 </td></tr> 
<tr><td>company3</td><td> 浙 江 杭 州 </td><td>2 年 </td></tr> 
<tr><td>company4</td><td> 广 东 深 圳 </td><td>1 年 </td></tr> 

</table> 


执行 以 上 代码 ， 则 可 在 网 页 中 创建 一 个 如 图 2-10 所 示 的 表格 。 


< 注意 : 图 2-10 中 的 表 与 图 2-9 中 表格 的 差别 是 “毕业 生 就 业 情况 统计 ”并 没有 显示 在 
表格 的 某 个 单元 格 内 。 


沪 rar 文档 之 表格 标记 演示 效果 -上 SS 

| 文件 四 “办 得 G) 查看 由 收藏 和 工具 中 帮助 中 

| 加 更 - 轴 - 四国 机 | 万 本  D 
EE we he EISE 


【毕业 生 就 业 情况 统计 

公司 名 称 | 地 址 签约 时 间 
company1 | 四 川 成 都 | 半年 
company2 | 江苏 南 京 | 未 签约 
company3 | 浙江 杭州 | 年 
company4 | 广东 深圳 1 年 


图 2-10 在 HTML 文档 中 设置 表格 的 标题 
2.5.2 ”表格 体 标记 


tbody 是 在 table 中 使 用 的 ， 用 来 指明 将 它 包括 的 各 表格 行 作为 表格 的 主体 部 分 。 使 用 
<tbody> 标 记 的 好 处 是 : 如果 表格 中 的 内 容 很 多 ,如 有 上 百 行 的 数据 记录 ， 浏 览 器 默认 情况 
下 会 将 所 有 的 数据 下 载 完 之 后 再 显示 整个 表格 ， 但 添加 了 <tbody> 标 记 后 ， 浏 览 器 会 分 行进 
行 显示 , 即 每 下 载 一 行 数据 就 立即 显示 一 行 , 因此 能 加 快 大 型 表格 的 显示 速度 。 使 用 <tbody> 
标记 ， 可 以 将 表格 划分 为 一 个 个 单独 的 部 分 ， 即 可 将 表格 中 的 一 行 或 几 行 合成 一 组 分 别 进行 
显示 。 例 如 : 


<table width="423" border="0" cellspacing="0" cellpadding="0"> 
<tbody bgcolor="#00CCFF"> 
<tr> 
<td width="204"> 单 元 格 数据 1</td> 
<td width="219"> 单 元 格 数 据 2</td> 
</tr> 
<tr> 
<td> 单 元 格 数据 3</td> 
<td> 单 元 格 数据 4</td> 
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</tr> 
<tr> 
<td> 单 元 格 数据 5</td> 
<td> 单 元 格 数据 6</td> 
</tr> 
</tbody> 
</table> 


2.6 表单 标记 


HTML 表单 (Form) 是 HTML 的 一 个 重要 部 分 , 主要 用 于 采集 和 提交 用 户 输入 的 信息 。 
它 是 服务 器 端 程序 处 理 客 户 端 用 户 提交 的 各 类 信息 的 主要 工具 , 也 是 一 类 重要 的 网 页 元 素 。 
下 面 介 绍 HTML 中 与 表单 相关 的 语法 。 
2.6.1 表单 的 定义 语法 

表单 的 基本 语法 如 下 : 


<form action="url" method=*>... 


<input type=submit> 

<input type=reset> 

</form> 

其 中 ,ul 表示 处 理 该 表单 的 文件 路 径 ,* 表 示 处 理 表单 信息 的 方式 ,主要 有 GET 和 了 POST 
两 种 。GET 的 方式 是 将 表单 控件 的 name/value 信息 经 过 编码 之 后 ， 通 过 URL 发 送 ， 可 以 
在 地 址 栏 中 看 到 。 而 POST 则 是 将 表单 中 的 内 容 通 过 HTTP 发 送 ， 在 地 址 栏 中 看 不 到 表单 
的 提交 信息 。 那 什么 时 候 用 GET， 什 么 时 候 用 POST 呢 ? 一般 是 这 样 来 判断 的 ， 如 果 只 是 
为 了 取得 和 显示 数据 , 可 以 用 GET; 如 果 涉 及 数据 的 安全 、 保存 和 更 新 , 那么 建议 用 POST。 
表单 中 提供 给 用 户 的 输入 形式 为 : <input type=* name=** value=***>。 其 中 ，* 表 示 表 单元 
素 类 型 ， 主 要 有 text、password、checkbox、radio、image、hidden、submit 和 reset， 其 中 
设置 为 submit 时 ， 显 示 的 是 “提交 ”按钮 ， 设 置 为 reset 时 ， 显 示 的 是 “ 重 置 ”按钮 ，** 
表示 用 户 为 该 表单 元 素 定义 的 名 称 ， 该 名 称 的 定义 要 符合 CGI 标准 ;，*** 表 示 用 户 为 表单 
元 素 预 定义 的 值 。 下 面 详细 介绍 表单 中 的 常见 元 素 及 其 具体 功能 。 


2.6.2 在 文本 框 中 输入 文字 和 密码 


文本 域 <input type="text" 信用 于 在 表单 上 创建 单行 文本 输入 区 域 即 普通 文本 框 。 创 建文 
本 框 相 应 的 语法 格式 为 : <input type="text" name=" " value=" ">。 

密码 域 的 定义 与 文本 域 的 定义 基本 相同 ， 只 是 向 文本 框 输入 数据 时 ， 其 数据 以 圆 点 显 
示 。 创 建 密码 域 相应 的 语法 格式 为 : <input type=" password " name= "" 。 例 如 ， 通 过 下 
面 的 语句 可 以 创建 两 个 文本 域 和 一 个 密码 域 。 
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<form action="cgi-bin/post-query" method=POST> 

您 的 姓名 : 

<input type=text name= 姓 名 ><br> 

您 的 主页 : 

<input type=text name= 网 址 value=http://><br> 

您 的 密码 : 

<input type=password name= 密 码 ><br> 

<input type=submit value=" 发 送 "><input type=reset value=" 重 设 "> 
</form> 


保存 该 HTML 文档 并 用 正 浏览 器 打开 , 则 用 户 可 在 正 窗口 中 查看 如 图 2-11 所 示 的 表单 。 


村 !TnL 文 条 之 表单 标记 演示 效果 22 

| | 文件 @” 久 辑 E) 查看 中 1 工具 四 ” 本 
[ea DECEOPSL., 

IE 工本 号 司 


您 的 姓名 : Fas 
您 的 主页 : [retp:77wev. cec- ea 
您 的 密码 : 


图 2-11 含有 文本 框 和 密码 域 的 表单 实例 
2.6.3 ” 复 选 框 和 单 选 按钮 


定义 复 选 框 (CheckBox) 的 语法 格式 为 : <input type=checkbox name=…value=…>。 描 
述 复 选 框 被 选中 的 语法 格式 为 ，<input type=checkbox name value=…checked>。 例 如 : 


<form action="cgi-bin/post-query" method=POST> 
<input type=checkbox name= 商 品 1> 
镀 头 <p> 
<input type=checkbox name= 商 品 2 checked> 
香 莫 <p> 
<input type=checkbox name= 商 品 3 value=book> 
书籍 <p> 
<input type=submit><input type=reset> 
</form> 


保存 该 HTML 文档 并 用 正 浏览 器 打开 , 则 用 户 可 在 正 窗口 中 查看 如 图 2-12 所 示 的 表单 。 
定义 单 选 按 钮 (RadioButton) 的 相应 语法 格式 为 : <input type=radio name=*…value=*…>。 
描述 单 选 按钮 被 选中 的 语法 格式 为 : <input type=radio name value=…checked>。 例 如 : 


<form action="cgi-bin/post-query” method=POST> 
<input type=radio name= 水 果 > 
香 莫 <p> 
<input type=radio name= 水 果 checked> 
苹果 <p> 
<input type=radio name= 水 果 value= 楼 子 > 
桩 子 <p> 
<input type=submit><input type=reset> 
</form> 
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保存 该 HIML 文档 并 用 正 浏览 器 打开 , 则 用 户 可 在 正 窗口 中 查看 如 图 2-13 所 示 的 表单 。 


全 rel 文 失 之 表单 标记 演示 效果 = EGGSGEEEEEJES] IECOEEEEEEI3EEERESELC EC =I9lx| 

| 文件 中 篇 部 上 查看) 收 误 和 工具) >” 和 | 到 胃 千 到 ) 查看 WD 收 京 和 ) 工具 ”| 避 

[OO | De ia [Im -© MAGPe 

| 塘 本 加 | 色 ] Tvaa hea 本 加 3 EJ] 

所 关 F 

区 香 莫 

5 书籍 

提交 查询 内 容 “| 重要 

Eg 两 陨 夯 | 

图 2-12 含有 复 选 框 的 表单 实例 图 2-13 含有 单 选 按钮 的 表单 实例 
2.6.4 列表 框 


定义 列表 框 〈Selectable Menu) 的 基本 语法 格式 如 下 : 
<select name=*…*> 
<option value="…*>*… 
<option Value 一 …>… 
</select> 
描述 列表 框 中 某 项 被 选中 的 语法 格式 如 下 : 
<option value =…'selected>… 


例如 ， 通 过 下 列 代码 可 以 创建 一 个 列表 框 。 


<form action="bin/post-query" method=POST> 
您 所 到 过 的 国家 : <p> 
<select name=nation > 
<option> 美 
<option selected> 英 国 
<option value=My_Favorite> 日 本 
<option> 加 拿 大 
</select> 
<input type=submit><input type=reset> 
</form> 


保存 该 HIML 文档 并 用 正 浏览 器 打开 , 则 用 户 可 在 正 窗口 中 查看 如 图 2-14 所 示 的 表单 。 
如 果 在 <select> 标 记 中 添加 属性 multiple, 则 可 以 创建 一 个 允许 选择 多 个 选项 的 下 拉 列 表 。 
例如 ， 在 下 列 代码 中 ， 语 句 <select name=fruits size=3 multiple> 表 示 同 时 可 以 选择 3 个 选项 。 


<form action="bin/post-query" method=POST> 

您 所 到 过 的 国家 : <p> 

<select name=nation size=3 multiple> 
<option> 美 
<option selected> 英 国 
<option value=My_pscontry> 日 本 
<option> 加 拿 大 

</select> 
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<input type=submit><input type=reset> 
</form> 


保存 该 HTML 文档 并 用 正 浏览 器 打开 , 则 用 户 可 在 正 窗口 中 查看 如 图 2-15 所 示 的 表单 。 
< 骸 注意 ; 若 要 选择 多 个 选项 ， 则 应 先 按 住 Crtl 键 再 分 别 单 击 所 要 选择 的 选项 。 


Ei 习 1THL 文 关中 的 奈 记 演 示 效 果 WERE 
有] 女 件 下 六 缉 电 】 查看 W 收 帘 由 工具 I ”| 吉 EE 
可 Ed > MEERA 
ET 可 加 


| 加 所 -如 - 轩 回 久 | 记 里 
ER EE] 
EF 您 所 到 过 的 国家 


焰 所 到 过 的 国家 ， 

RE 
EE 
EE 


图 2-14 含有 列表 框 的 表单 实例 图 2-15 可 多 选 的 列表 框 的 表单 实例 


加 


2.6.5 文本 区 域 
文本 区 域 (textarea) 的 语法 格式 如 下 : 


<textarea name 一 …ITOWS 一 # COls=**>..*</textarea> 
其 中 ，* 和 ** 取 整数 ，rows 表示 文本 区 的 行 数 ，cols 表示 文本 区 的 列 数 。 例如， 通过 下 
列 代码 可 以 创建 一 个 5 行 60 列 的 文本 区 域 。 
<form action="cgi-bin/post-query" method=POST> 
<textarea name=comment rows=5 cols=60> 
</textarea> 
<p> 
<input type=submit><input type=reset> 
</form> 


执行 以 上 代码 后 将 在 浏览 器 窗口 中 看 到 如 图 2-16 所 示 的 页 面 。 


本 rar 广 御 中 的 标记 演示 效果 一 WiceasaE =lelx| 
总 铝 E) 查看 = NON A | 
> MNES 

全 全 aa htnl EE 


司 


典 班 了解 HT 语言 的 相关 委 训 < 


图 2-16 含有 文本 区 域 的 表单 实例 


2.6.6 ”表单 中 的 按钮 


在 表单 中 ， 可 以 用 input 标记 创建 按钮 。 将 input 标记 的 type 属性 设置 为 submit， 可 以 
创建 一 个 提交 按钮 ， 将 type 属性 设置 为 image， 可 以 创建 一 个 图 像 按钮 ， 用 来 提交 表单 数 
据 ; 将 type 属性 设置 为 reset， 可 以 创建 一 个 重 置 按 钮 ; 当 设置 type 属性 为 button 时 ， 则 可 


SS 下 
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以 定义 一 个 普通 按钮 。 为 方便 读者 掌握 以 上 4 种 按钮 形式 ， 在 表 2-1 中 将 以 上 按钮 的 定义 
做 了 一 个 总 结 。 

表 2-1 用 type 属性 定义 不 同 的 按钮 
功 


用 


作 


et 
E3 


type 属性 类 型 


<input type="submit"/> 提交 按钮 提交 表单 信息 
<input type="image"/> 图 像 按钮 用 图 像 做 的 提交 按钮 ， 用 于 提交 表单 信息 


b 的 用 户 输入 信息 清空 
需要 配合 JavaScript 脚本 使 其 具有 相应 的 功能 


<input type="reset"/> 


重 置 按钮 
普通 按钮 


2.6.7 ”隐藏 表单 的 元 素 


隐藏 表单 元 素 的 语法 格式 为 : <input type=hidden value=*>， 其 功能 是 在 浏览 网 页 时 使 
浏览 器 不 显示 这 个 表单 字段 元 素 ， 但 在 提交 表单 时 将 这 个 隐藏 表单 元 素 的 name 属性 和 
value 属性 值 发 送 给 服务 器 。 例 如 ， 有 以 下 程序 : 
<form action="/cgi-bin/post-query” method=POST> 
<input type=hidden name=add value=hoge@hoge.jp> 
这 里 是 一 个 隐藏 表单 元 素 <p> 
<input type=submit><input type=reset> 

</form> 


执行 以 上 代码 后 ， 将 在 浏览 器 窗口 中 看 到 如 图 2-17 所 示 的 页 面 。 


<input type="button"/> 


入 TNL 文 着 之 表格 标记 效果 演示 且 寻 二村 证 于 
」 文件 四 编 缚 外 查看 中 收 芝 册 工具 UT 更 助 


JO -© ADP Tim © 
[rr re ee > 


这 里 是 一 个 隐藏 表单 元 素 是 


提交 查询 内 容 | 重 杜 


可 有 旺 


图 2-17 隐藏 表单 元 素 的 实例 
2.7 在 HTML 中 详 入 PHP 代码 


PHP 代码 和 HTML 代码 在 语法 和 编译 解释 方式 上 各 不 相同 ， 所 以 当 需 要 在 HTML 代 
码 中 嵌入 PHP 代码 时 ， 要 特别 加 入 PHP 定 界 符 。PHP 定 界 符 有 以 下 4 种 形式 。 
(1) <?php*…?> 
这 是 PHP 定 界 符 的 标准 形式 ， 建 议 读者 使 用 这 种 形式 。 例 如 : 
<?php 


echo "您 好 !"; 
ss 
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2 SI 
这 是 PHP 定 界 符 的 简写 形式 。 在 使 用 这 种 定 界 符 前 ， 必 须 在 配置 文件 php.ini 中 设置 
short_open tag = On， 然 后 重新 启动 Apache 服务 器 ， 使 设置 生效 。 
(3) <script language="php">…</script> 
这 种 形式 提供 脚本 引入 ， 其 作用 是 指定 PHP 编译 器 来 解释 <scrip 伺 与 </scrip 人 之 间 的 脚 
本 程序 。 例 如 : 
<script language="php"> 
$a=" 您 好 !"; 
echo $a; 
</script> 
(4) <9%6…90> 
这 种 形式 是 ASP 语言 的 定 界 符 。 如 果 要 在 PHP 文件 中 使 用 这 种 形式 的 定 界 符 ， 必 须 
在 配置 文件 php.ini 中 设置 asp_tags = On， 然 后 重新 启动 Apache 服务 器 ， 使 其 设置 生效 。 


2.8 案例 剖析 : 制作 网 上 问卷 调查 表单 


在 网 上 进行 问卷 调查 ， 是 互联 网 时 代 一 种 比较 流行 和 快捷 的 问卷 调查 形式 ， 不 但 可 以 
提高 调查 的 工作 效率 ， 保 证 调查 的 准确 性 ， 还 可 以 大 大 降低 调查 所 需 的 运行 成 本 。 下 面 通 
过 一 个 实例 来 说 明 如 何 利用 表单 及 其 他 HIML 标记 制作 表单 。 


2.8.1 程序 功能 介绍 
本 程序 要 实现 的 主要 功能 是 利用 表单 获取 广大 读者 对 某 图 书 的 反馈 意见 。 该 问卷 分 为 


若干 个 调查 项 目 ， 读 者 可 通过 填写 网 页 上 呈现 的 相关 表单 项 参与 问卷 调查 ， 其 网 页 运行 的 
实际 效果 如 图 2-18 所 示 。 


| 教材 宪 称 :cr 程序 设计 。 ISBN, x xxxxxxx1ll2 
该 者 个 人 资料 ， 
姓名 本 年 岭 丰 性 别 厚 司 
文 伏 程度 [3 电子 邮箱 Fi8165 con 


您 使用 本 书 是 作为 。 区 指定 教材 王 选用 教材 记 辅导 教材 局 自学 教材 
和 您 对 本 书 封面 设计 的 满意 度 。 所 很 满意 三 满意 呈 一 般 呈 不 满意 
和 您 对 本 书 印刷 质量 的 满意 度 。 忆 很 满 划 三 满意 人 一 般 王 不 满 基 


您 对 本 书 总 体 的 满意 度 ， 厂 很 注意 形 ] 注音 三 一 般 三 不 满意 


图 2-18 网 上 问卷 调查 表 
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2.8.2 程序 代码 分 析 
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<form action= 
<table width="961" height="403" border="0" cellpadding="0" cellspacing="0"> 
<tr align="center"> 


method="post"> 


基于 上 述 对 网 上 问卷 调查 的 功能 分 析 和 描述 ， 可 以 编写 如 下 程序 代码 。 


<html><head> 
<title> 网 上 问卷 调查 </title> 


<td width="221" height="34"><span class="STYLE1"> 教 材 名 称 :C# 程 序 设 计 </span></td> 
<td width="203"><span class="STYLE1">ISBN: Xx Xxx XxXxX112</span></td> 


<td width="71">&nbsp;</td> 
<td width="466">&nbsp;</td> 


</tr> 


<td height="34" colspan="4">&nbsp; &nbsp;&nbsp; &nbsp;&nbsp; &nbsp; 读 者 个 人 资料 : </td> 


</tr> 
<tr align="center > 


<td height="31"> 姓 名 </td> 

<td align="left"><label> 

<input type="text" name="textfield" id="textfield" /> 
</label></td> 

<td> 年 龄 </td> 

<td align="left"> 

<input type="text" name="textfield2" id="textfield2" /> 
性 别 

<label> 

<select name="select" id="select"> 

<option value=" 男 "> 男 </option> 

<option value=" 女 "> 女 </option> 

</select> 

</label></td> 


</tr> 
<tr align="center > 


<td height="34"> 文 化 程度 </td> 

<td align="left"> 

<input type="text" name="textfield3" id="textfield3" /> 
<td> 电 子 邮 箱 </td> 

<td align="left"> 

<input type="text" name="textfield4" id="textfield4" /> 


</tr> 


<td height="34" colspan="4"><hr width="85%" /></td> 


</tr> 


</td> 


</td> 


<td height="42" colspan="4" align="center"> 您 使 用 本 书 是 作为 : 
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<input name="checkbox" type="checkbox" id="checkbox" value="selejc" /> 
指定 教材 
<input type="checkbox" name="checkbox2" id="checkbox2" value="selesyjc"/> 
选用 教材 
<input name="checkbox3" type="checkbox" id="checkbox3" value="selefdjc" /> 
辅导 教材 
<input type="checkbox" name="checkbox4" id="checkbox4" value="selezxjc" /> 
自学 教材 </td> 

</tr> 

<tr> 

<td height="42" colspan="4" align="center"> 您 对 本 书 封 面 设计 的 满意 度 : 
<input name="checkboxS5" type="checkbox" id="checkbox5" value="selejc" /> 
很 满意 
<input type="checkbox" name="checkbox5" id="checkbox6" value="selesyjc"/> 
满意 
<input name="checkbox5" type="checkbox" id="checkbox7" value="selefdjc" /> 
一 般 
<input type="checkbox" name="checkbox5" id="checkbox8" value="selezxjc" /> 
不 满意 </td> 

</tr> 

<tr> 

<td height="42" colspan="4" align="center"> 您 对 本 书 印刷 质量 的 满意 度 : 
<input name="checkbox6" type="checkbox" id="checkbox9" value="selejc" /> 
很 满意 
<input type="checkbox" name="checkbox6" id="checkbox10" value="selesyjc"/> 
满意 
<input name="checkbox6" type="checkbox" id="checkbox11" value="selefdjc" /> 
一 般 
<input type="checkbox" name="checkbox6" id="checkbox12" value="selezxjc" /> 
不 满意 </td> 

</tr> 

<tr> 

<td height="42" colspan="4" align="center"> 您 对 本 书 总 体 的 满意 度 : 
<input name="checkbox7" type="checkbox" id="checkbox13" value="selejc" /> 
很 满意 
<input type="checkbox" name="checkbox7" id="checkbox14" value="selesyjc"/> 
满意 
<input name="checkbox7" type="checkbox" id="checkbox15" value="selefdjc" /> 
一 般 
<input type="checkbox" name="checkbox7" id="checkbox16" value="selezxjc" /> 
不 满意 </td> 

</tr> 

<tr> 

<td colspan="4" align="center"> 
<input type="submit" name="button" id="button" value=" 提 交 " /> 
<input type="reset" name="button2" id="button2" value=" 重 置 "/> </td> 

</tr> 

</table></form></body></html> 
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2.9 本 章 小 结 


章 主 要 介绍 了 HTML 标记 语言 的 基础 知识 ， 着 重 讲述 了 表格 标记 语言 、 表 单 标记 语 


、 文 本 格式 标记 语言 和 超 链接 标记 等 ， 这 些 都 是 构成 网 页 的 主要 元 素 。 


2.10 练 习 题 


网 页 中 能 够 支持 的 图 像 格式 有 哪些 ? 它们 有 什么 特点 ? 

简 述 一 个 表单 至 少 应 由 哪 几 个 部 分 组 成 。 

什么 是 HIML 语言 ? 请 写 出 一 个 完整 的 HTML 文档 的 基本 结构 。 
文本 对 齐 属性 align， 其 主要 取 值 有 哪些 ? 分 别 代表 什么 含义 ? 


ES 


2.11 上 机 实战 


利用 HIML 相关 标记 ， 制 作 一 个 网 站 登录 页 面 ， 其 效果 如 图 2-19 所 示 。 


三 无 标题 文档 Vindovs IatERRLIESE 


Rr 


图 2-19 网 站 用 户 登录 页 面 
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知识 点 : 

PHP 语法 的 总 体 特 点 
PHP 中 的 数据 类 型 

PHP 的 常量 与 变量 

PHP 中 的 运算 符 和 表达 式 
PHP 程序 的 主要 流程 控制 
本 章 导读 : 


PHP 是 一 种 嵌入 在 HTML 代码 中 的 脚本 语言 ， 它 由 服务 器 负责 解释 ， 具有 自己 的 语法 
结构 。 它 可 以 用 于 管理 动态 内 容 、 支 持 数据 库 、 处 理会 话 跟踪 ， 甚 至 构建 整个 电子 商务 站 
点 。PHP 支持 许多 流行 、 非 流行 的 数据 库 ， 包 括 MySQL、PostgreSQL、Oracle、Sybase、 
Informix 和 Microsoft SQL Server。 本 章 主要 介绍 如 何在 Windows 系统 平台 上 开发 PHP 程 
序 以 及 如 何在 HTML 网 页 中 加 入 合法 的 PHP 程序 代码 。 


回回 罗网 加 


3.1 PHP 语法 综述 


PHP 之 所 以 能 在 短 短 的 十 几 年 里 得 到 迅速 发 展 ， 用 户 遍 及 全 球 ， 被 数 以 亿 计 的 程序 开 
发 人 员 所 推 综 ， 这 与 PHP 与 生 俱 来 的 语法 特点 和 优势 是 分 不 开 的 。 


3.1.1 PHP 程序 语言 的 特点 


PHP 的 大 多 数 语法 来 源 于 C, 也 有 一 部 分 PHP 特性 借鉴 了 Java 和 Perl。PHP 程序 语言 
最 初 发 明 者 的 初衷 , 是 让 Web 开发 人 员 能 够 快速 、 高 效 地 写 出 动态 页 面 数据 库 设 计 的 内 容 。 
PHP 不 仅 拥有 其 他 同类 脚本 所 共有 的 功能 ， 更 有 着 它 自 身 的 特点 ， 其 独特 之 处 主要 表现 在 
以 下 几 点 ; 
口 “ 代 码 完全 开放 。 所 有 的 PHP 程序 代码 都 可 以 免费 、 自 由 地 交流 。 在 互联 网 上 ， 所 
有 PHP 用 户 都 可 以 得 到 大 量 符合 自己 需求 的 PHP 源 程序 。 
口 ” 完 全 免费 。 使 用 PHP 开发 相关 的 Web 应 用 程序 无 需 支付 任何 费用 。 
口 ” 功 能 强大 。PHP 几乎 无 所 不 能 ， 具 体 到 Web 开发 上 ，PHP 能 完成 任何 一 款 服务 器 
端 程序 所 能 完成 的 工作 ， 如 收集 表单 数据 、 生 成 动态 网 页 、 发 送 /接收 Cookies 等 。 
当然 ，PHP 强大 的 功能 远 不 局 限于 此 。 
口 语法 结构 简单 -PHP 结合 了 C 语言 和 Perl 语言 的 特色 , 坚持 以 基础 语言 开发 程序 ， 
所 编写 的 程序 更 简单 易 懂 。 对 于 众多 以 前 接触 过 C 语言 的 用 户 来 说 ,只 需 了 解 PHP 
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的 基本 语法 , 然后 掌握 一 些 PHP 独 有 的 函数 ， 就 能 轻松 地 进入 PHP 程序 设计 殿堂 。 
口 强大 的 数据 库 支持 。PHP 几乎 支持 所 有 主流 、 非 主流 的 数据 库 ， 如 MySQL、 
Microsoft SQL Server、Orcale、Dbase、Sybase、Informix、InterBase 和 Access 等 。 
口 “” 代 码 执行 效率 高 。 与 其 他 同类 CGI 比较 ，PHP 消耗 的 系统 资源 更 少 ， 如 果 用 户 采 上 
Apache 作为 服务 器 , 则 服务 器 系统 可 以 只 负责 脚本 解释 , 无需 承 担 其 他 额外 的 任务 。 
口 ”面向 对 象 编程 。 PHP 提供 了 类 和 对 象 , 基于 Web 的 编程 工作 需要 面向 对 象 编程 能 
力 。PHP 支持 构造 器 、 提 取 类 等 。 


3.1.2 PHP 无 可 比拟 的 优势 


任何 使 用 过 命令 式 程序 设计 语言 的 用 户 都 会 对 PHP 非常 熟悉 ， 如 使 用 过 C 或 者 Perl 
等 具有 类 似 风格 和 语法 结构 的 用 户 , 一 般 能 够 很 快 上 手 PHP.。 尽管 PHP 的 初衷 是 用 于 Web 
设计 ， 但 是 它 也 能 够 作为 命令 行 语言 使 用 。 

PHP 可 以 帮助 网 站 开发 人 员 为 网 站 的 访问 者 提供 本 地 化 的 服务 。 当 远 端 用 户 单 击 进入 
网 站 时 ， 网 站 会 根据 远 端 用 户 各 自 浏览 器 的 设置 自动 地 以 其 母语 向 其 提供 页 面 。 如 果 被 请 
求 的 语言 文件 存在 ， 那 么 用 户 所 看 到 的 文本 就 是 其 母语 ; 如 果 语 言 文件 不 存在 ， 那 么 文本 
就 是 默认 的 英语 或 者 Web 开发 人 员 指定 的 其 他 语言 。 

PHP 可 与 Apache 自然 结合 ， 作 为 一 个 模块 编译 成 Apache 二 进 制 文件 。 由 于 Apache 
能 够 运行 在 Windows、Linux、Solaris 和 其 他 各 种 操作 系统 平台 上 ， 因 此 ， 单 就 这 一 方面 优 
势 来 说 ， 其 他 Web 编程 语言 就 无 法 与 PHP 相 比 拟 。 此 外 ， 利 用 Apache 构建 的 Web 服务 
器 还 有 跟踪 记录 的 功能 ， 因 此 其 安全 性 能 够 保持 在 最 高 的 优先 级 上 。 从 这 个 角度 来 说 ， 
ASP.NET 或 ASP 默认 的 运行 平台 IS 是 无 法 与 PHP 相 比 拟 。 最 后 ，PHP 拥有 更 小 的 代码 
路 径 ， 这 意味 着 减少 了 分 析 和 执行 PHP 页 面 服务 器 端 代码 的 时 间 ， 因 此 运行 更 加 迅速 。 

下 面 ， 通 过 表 3-1 来 总 结 一 下 PHP 与 其 他 Web 编程 语言 相 比 ， 其 优势 所 在 。 

表 3-1 PHP 与 其 他 Web 语言 的 比较 


语言 

指标 性 能 i bal 
操作 系统 均 可 均 可 
Web 服务 器 多 种 区 可 
代码 执行 效率 | ” 亿 世 
稳定 性 全 差 
开发 时 间 每 长 
程序 语言 PHP 不 限 
网 页 结合 全 关 
学 习 门 楼 低 高 
函数 支持 多 不 定 
系统 安全 全 信 
升级 速度 忆 天 
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3.2 数据 类 型 


PHP 共有 8 种 数据 类 型 : 布尔 、 整 数 、 浮 点 数 、 字 符 串 、 数 组 、 对 象 、 资 源 和 NULL。 
3.2.1 布尔 数据 类 型 


布尔 数据 类 型 具有 TRUE 与 FALSE 两 个 值 , 且 不 区 分 大 小 写 , 即 可 以 写成 true 与 false， 
或 是 True 与 False。 


例如 ， 下 列 代码 声明 了 变量 Sx、$y 与 $z 的 数据 类 型 是 布尔 值 TRUE。 


<html> 
<head> 
<title></title> 
</head> 
<body> 

$x = True; 
S$y = True; 
$z = true; 
echo "x = $x, y = $y, z = $z"; 
</body> 
</html> 


如 图 3-1 所 示 ， 在 HTML 语言 中 嵌入 以 上 语句 ， 并 保存 为 PHP 文件 到 网 站 主 目 录 中 ， 
通过 浏览 器 可 查看 程序 运行 结果 如 图 3-2 所 示 。 


图 3-1 在 HIML 文档 中 插入 PHP 代码 


< 注意 : 在 将 PHP 源 代码 嵌入 到 HTML 文档 中 时 ， 一 定 要 将 其 插入 到 HTML 文档 的 主 
体 ， 即 body 部 分 内 。 为 了 节约 篇 幅 ， 在 本 书后 面 介绍 的 源 代码 示例 中 将 省 去 
HTML 代码 部 分 ， 而 直接 罗列 PHP 源 代码 。 
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下 列 代码 声明 了 变量 Sx、$y 与 $z 的 数据 类 型 是 布尔 值 FALSE。 


$x = False; 
$y = False; 
$z = False; 


echo "x = $x, y = $y, z = $2z"; 
在 HTML 语言 中 嵌入 以 上 语句 ， 并 保存 为 PHP 文件 后 ， 在 浏览 器 中 查看 的 程序 运行 
结果 如 图 3-3 所 示 。 


(Shttp: /focalhos /HTD oolstatenent hp > [hp /lechos /Pbeoksorr ee/beol tonenl] Ti 


EE = + x lr = GO le /rr 


文件 中。 六 圈 名 查看， 收 戌 天 如 工具 加 玫 胞 00 ETTEIT 
| | 


x=1,y=1, z=1 


[厂矿 午 Intermt 
图 3-2 布尔 数据 类 型 的 举例 (1) 图 3-3 布尔 数据 类 型 的 举例 (2) 


如 果 要 将 其 他 的 数据 类 型 转换 成 布尔 数据 类 型 ， 需 要 在 前 面 加 上 (bool) 或 是 (boolean)。 
例如 : 

$a = 100; 

$b = 0; 

echo "a = "，(bool)$a, ", b = "，(Boolean)$b; 

在 HTML 语言 中 嵌入 以 上 语句 ， 并 保存 为 PHP 文件 后 ， 在 浏览 器 中 查看 的 程序 运行 
结果 如 图 3-4 所 示 。 


/Shttp //1ocalhost/PHPbooksource/boolstatenenl2 pip 1 


OO le /ener ry | | 5 
」 文件 了 编辑 E) 查看 W) 收 藏 只 (A) 工具 CI) 帮助 0 
这 收 中 天。 外 htty://locahesUPidooksoren/borlstatem. .| | 


人 it 


图 3-4 布尔 数据 类 型 的 举例 (3) 


用 户 可 以 使 用 gettypeO 函 数 来 返回 数据 类 型 的 种 类 。 例 如 ， 在 HTML 语言 中 嵌入 以 下 
PHP 代码 : 


$a = 187; 

$b=0; 

echo "a 的 数据 类 型 是 : " gettype($a); 
echo "<br />"; 


echo "a 的 数据 类 型 是 : ", gettype((bool)$a); 
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echo "<br />"; 

echo "b 的 数据 类 型 是 : ", gettype($b); 

echo "<br />"; 

echo "b 的 数据 类 型 是 : ", gettype((Boolean)$b); 


在 浏览 器 中 查看 程序 运行 结果 如 图 3-5 所 示 。 


」 文件 四 ”编辑 到) 查看 W) 收 若 实 () 工具 CD) 帮助 0 
| 


a 的 数据 类 型 是 : integer 
的 数据 类 型 是 : boolean 
: integer 
: boolean 


Te 

图 3-5 用 gettype0 函 数 返回 数据 类 型 
如 果 要 将 其 他 的 数据 形态 转换 成 布尔 数据 类 型 ， 下 列 数值 被 认为 是 布尔 值 FALSE。 
布尔 值 FALSE 本 身 。 
整数 0。 
浮 点 数 0.0。 
空 字符 串 以 及 字符 串 "0"。 
没有 元 素 的 数组 。 
没有 成 员 变 量 的 对 象 。 
特殊 的 数据 类 型 NULL (包含 未 设置 的 变量 ) 。 
除了 0 以 外 的 数字 都 被 认为 是 布尔 值 TRUE， 包 含 负数 。 


3.2.2 ”整数 数据 类 型 


DOOOODODD 


口 


整数 可 以 使 用 十 进 制 、 八 进 制 或 是 十 六 进 制 来 表示 ， 有 效 范 围 视 操作 系统 而 定 。 在 
Windows 操作 系统 中 ， 有 效 范 围 是 -2147483648 一 2147483647。 

(1) 八进制 的 整数 以 0 开头 ， 例 如 : $x = 0123。 

(2) 十 六 进 制 的 整数 以 0x 开头 ， 例 如 : $x = 0xlE。 

(3) 如 果 要 显示 的 数字 超出 了 整数 数据 类 型 的 有 效 范围 ，PHP 会 使 用 浮 点数 进行 表示 。 
例如 : 

$x = 2147483647; 

echo "没有 超过 整数 数据 类 型 的 范围 ，x 的 数据 类 型 是 :", gettype($x),,"<br>" 

$x = 2147483648; 

echo "超过 整数 数据 类 型 的 范围 ，x 的 数据 类 型 是 :，" gettype($x); 


在 浏览 器 中 查看 以 上 代码 输出 结果 ， 如 图 3-6 所 示 。 
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这 尿 基站 。 笨 http_ 1/localosVHEtooksewre 


访 有 超过 整 教 教 把 类 型 的 范围 , i 让 inte 


超过 整数 数据 类 型 的 范围 ，z 的 数据 类 型 是 


图 3-6 整数 数据 类 型 的 举例 
(4) 如 果 要 将 其 他 的 数据 类 型 转换 成 整数 数据 类 型 ， 在 前 面 加 上 (int) 或 (integer)。 
(5) 下 列 代码 将 布尔 数据 类 型 转换 成 整数 数据 类 型 。 
$x = TRUE; 
$y = FALSE:; 
echo "x =", (int)$x, ", y = ", (integen)$y; 
浏览 器 的 输出 为 : x= 1.y= 0。 
A 下 列 代码 将 浮 点 数 数据 类 型 转换 成 整数 数据 类 型 。 
$x = 2.342; 
$y = pow(2, 32); 
echo "x =", (int)$x, ", y = ", (integer)$y; 
浏览 器 的 输出 为 : x=2,y=0。 
< 注意 : $y=pow(2, 32) 的 数值 超出 了 整数 数据 类 型 能 够 显示 的 范围 (通常 是 +2.15E+9= 2?1 )， 
所 得 到 的 结果 是 无 法 预测 的 ， 且 PHP 不 会 显示 警告 或 错误 的 信息 。 
(7) 不 要 将 未 知 的 小 数 使 用 (inb 或 (integenD 强 制 转换 成 整数 数据 类 型 进行 计算 ， 因 为 
所 得 到 的 结果 是 无 法 预测 的 。 例 如 ， 下 列 程序 的 计算 结果 是 错误 的 : 
echo (int)((0.1+0.7) * 10); 


浏览 器 的 输出 为 7， 而 不 是 正确 的 8。 
3.2.3 浮 点 数 数据 类 型 


浮 点 数 的 有 效 范 围 视 操 作 系统 而 定 。 浮 点 数 使 用 e 或 了 来 表示 以 10 为 底 的 指数 ， 有 效 
小 数 点 可 达 14 位 。 
(1) 下 列 代码 声明 了 变量 $Sx、$y、$z 的 数据 类 型 是 浮 点 数 。 
$x = 2.234; 
$y = 5.2e5; 
$z = 3.2E-5; 
echo "x = $x, y = $y, z = $z"; 


以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 3-7 所 示 。 


第 3 章 PHP 的 基本 语法 


(2) 可 以 使 用 round0 函 数 来 将 浮 点 数 四 舍 五 入 ， 转 换 成 指定 小 数 点 精度 的 整数 或 浮 
点 数 。 例 如 : 


echo round(3.4),"<br>"; 

echo round(3.5),"<br>"; 

echo round(3.6, 0),"<br>"; /保留 0 位 小 数 ， 对 第 一 位 小 数 四 舍 五 入 
echo round(1.95583, 2),"<br>"; 1/ 保留 2 位 小 数 ， 对 第 三 位 小 数 四 舍 五 入 
echo round(1241757, -3),"<br>"， ”// 从 整数 的 右边 开始 ， 对 第 三 位 整数 四 舍 五 入 
echo round(5.045, 2),"<br>"; 

echo round(5.055, 2),"<br>"; 


其 中 ，"<br>" 表 示 在 浏览 器 中 和 输出 时 在 此 处 强制 换行 。 
以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 3-8 所 示 。 


nt Tp -Bi 


文件 四 “亲自 四 “ 喜 看 中 要 康 夹 (工具 WD 帮助 | 
PR 和 waveatovpeyoaooucyavttte | | 


文件 四” 编 醒 加 ” 杰 者 外 必要 天 QW) 工具 中 乾 币 有 
这 中 天。 短 htto iilneuhntyPlftooksoareo lntstate 


xz = 2.234 y = 520000，z = 3. -005 


图 3-7 浮 点 数据 类 型 的 举例 (1) 图 3-8 浮 点 数据 类 型 的 举例 (2) 


(3) 可 以 使 用 ceil0 函 数 来 将 浮 点 数 无 条 件 进位 ， 转 换 成 整数 ， 但 是 ceil0 函 数 返回 的 
值 仍然 是 浮 点 数 数据 类 型 。 例 如 : 


echo ceil(4.3); // 返 回 浮 点 数 5 
echo ceil(9.999); /| 返回 浮 点 数 10 


(4) 可 以 使 用 floor0 函 数 来 将 浮 点 数 无 条 件 舍 去 ， 转 换 成 整数 ， 但 是 floor0 函 数 返回 
的 值 仍然 是 浮 点 数据 类 型 。 例 如 : 


echo floor(4.3); // 返 回 浮 点 数 4 
echo floor(9.999); // 返 回 浮 点 数 9 


< 注意 : 不 管 是 使 用 round、ceil、floor 还 是 (int) 来 转换 浮 点 数 ， 未 知 的 小 数 在 计算 中 因 
精度 转换 的 关系 ， 会 产生 无 法 预期 的 结果 。 例 如 : 


floor(((0.1+0.7)*10)) 
浏览 器 的 输出 为 7， 而 不 是 正确 的 8。 
3.2.4 字符 串 数据 类 型 


字符 串 使 用 单 引号 或 是 双 引 号 ， 将 字符 串 的 内 容 包 含 起 来 。 例 如 : 


$x = "字符 串 1"; 
$y = 'Hello' 
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(1) PHP 的 字符 串 只 能 表示 256 个 字符 ， 所 以 它 不 支持 Unicode。 

(2) 可 以 将 变量 的 名 称 使 用 大 括号 包含 起 来 ， 和 其 他 的 字符 串 连 接 。 例 如 : 
$str = "book"; 
echo "There is a $str"; 


echo "There are three {S$str}s","<br>"; 
echo "There are three {$str}s"; 


其 中 ，"<br>" 表 示 在 浏览 器 中 输出 时 在 此 处 强制 换行 。 
以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 3-9 所 示 。 


3 


」 文件 于 护 铝 于 直 看 W) 收藏 夫 W) 工具 中 帮助 QD 


六 中 天 http /oesost /Pbooksoures/strinestat. .| | 


There is a bookThere are three books 
There are three books 


图 3-9 字符 串 数据 类 型 的 举例 (1) 
(3) 可 以 使 用 下 列 方式 取出 字符 串 中 的 某 个 字符 。 


$str = "Dictionary"; 
echo "第 1 个 字符 是 ", $str{0},"<br>"; 
echo "第 4 个 字符 是 ", $str{3},"<br>"; 


以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 3-10 所 示 。 
GO le ocion Urb esl st oer set str Bs x fe 
」 文件 钨 绒 中 ”查看 WD 收藏 交工 具 GD) 帮助 0 
窟 中 二 天 和 http//loedbor/Padooksowree/strinestot .| | 


第 1 个 字符 是 D 
第 4 个 字符 是 + 


下 
[ml ml ml | | [ET 
图 3-10 字符 串 数据 类 型 的 举例 (2) 
(4) 可 以 使 用 strlen0 函 数 取得 字符 串 的 长 度 。 例 如 : 


S$str = "Dictionary"; 

echo "最 后 一 个 字符 是 ", $str{strlen (S$str) -1}, "<br />"; 

最 终 在 浏览 器 中 输出 的 结果 : 最 后 一 个 字符 是 y。 

(5) 两 个 字符 串 要 连接 时 ， 中 间 使 用 “.” 号 连接 起 来 ， 使 用 “+” 号 没有 作用 。 例 如 : 


$x = "Hello"; 
$y = "world"; 


Sstr = $x . $y; 
echo $str; 


最 终 在 浏览 器 中 输出 的 结果 如 图 3-11 所 示 。 


/Shttp://localhost/PHPbosksourcefstriaestet sse 
OE tp /localhost/Pribookso Bsr x es pp- 
」 文件 四 编 暗 四 查看 收藏 天 工具 GD 和 助 0 
误 收 荐 亚 。 四 http://1ocalioswPHFbooksouree/stringstat. 


Helloworld 


划 
志 卫 到 天 居于 国力 国 -IT | 硬 "| 玉 100% 及 


图 3-11 字符 串 数据 类 型 的 举例 (3) 


(6) 在 将 字符 串 与 数字 相 加 的 时 候 ， 结 果 会 得 到 数字 。 字 符 串 会 被 转换 成 字符 串 开头 
能 够 转换 的 数字 ， 例 如 : 


$x = 2+"12.5"."<br>"; //$x 是 浮 点 数 (14.5) 
echo $x; 

$x = 1 + "-2.3e4"."<br>"; //$x 是 浮 点 数 (-22999) 
echo $x; 

$x = 1 + "mynumber-1.3e3"."<br>"; //$x 是 整数 (1) 
echo $x; 

$x = 1 + "mynumber"."<br>"; //$x 是 整数 (1) 
echo $x; 

$x = 1 + "10 books"."<br>"; //$x 是 整数 (11) 
echo $x; 

$x = 5+ "10.2 tables"."<br>"; //$x 是 浮 点 数 (15.2) 
echo $x; 

$x = "10.0 books" + 1; //$x 是 浮 点 数 (11) 
echo $x; 

echo "<br>"; // 强 制 换行 

$x ="10.0 table1" + 1.0; //$x 是 浮 点 数 (11) 
echo $x; 


通过 浏览 器 查看 ， 将 得 到 如 图 3-12 所 示 的 执行 结果 。 


[ht //localhos /PThooksour ce/ strinrststencnt] 5h) 77070 


$x en: 


_ 交 件 加 ”名 加 ” 豆 雪 吕 ” 中 庆 天 WW 工具 人 D 天 了 助 把 
| 


图 3-12 字符 串 数据 类 型 的 举例 (4) 
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(7) 可 以 使 用 ord0 函 数 取得 字符 的 ASCH 码 。 例 如 : 


Sstr = "\n"; 
echo "ASCI 码 =", ord($str); 


浏览 器 的 输出 结果 为 : ASCII 人 码 = 10 
(8) 可 以 使 用 chr0 函 数 将 ASCII 码 转 换 成 字符 。 例 如 : 
echo "字符 = ", chr(67); 


echo "<br>"; 
$str = sprintf(" 这 个 字符 = %c", 65); 


echo $str; 
其 中 ，sprintfl) 函 数 用 于 返回 一 个 格式 字符 串 ， 浏 览 器 的 最 终 输出 结果 为 : 
字符 =C 


这 个 字符 =A 
TRUE 将 转换 成 字符 串 "1"， 布 尔 值 FALSE 将 转换 成 空 字符 串 ""。 
(10) 下 列 代码 将 浮 点 数 转换 成 字符 串 : 


$a = 1.5e-3; 
echo(string)$a，"<br />"; 


浏览 器 的 输出 结果 为 : 0.0015 
3.2.5 ” 转 义 字符 串 
要 在 字符 串 中 表示 特殊 字符 时 ， 需 要 在 特殊 字符 前 面 加 上 一 个 “\” 号 。 如 表 3-2 所 示 
是 常见 转 义 字符 的 表示 方法 。 
表 3-2 转 义 字符 及 其 说 明 


特殊 字符 说 明 
un 换行 
Retum 
\t Tab 键 
\ \ 符号 
\$ $ 符号 
w " 符号 
入 ' 符号 
\nnn 八进制 表示 的 字符 ，n 为 0 一 7 的 数字 
\xnn 十 六 进 制 表示 的 字符 ，n 为 0 一 9 的 数字 以 及 A~F 的 字母 
例如 : 


echo ' 奥 巴 马 说 : "Nl can™,"<br>"; 
echo 要 删除 FW*.*?',"<br>"; 
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echo 要 删除 E:\*.*?',"<br>"; 
$x = 160; 
echo "\$x = ", $x; 


以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 3-13 所 示 。 
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图 3-13 转 义 字 符 串 数据 类 型 的 举例 


3.2.6 ”数组 数据 类 型 


PHP 的 数组 可 以 是 一 维 数组 ， 也 可 以 是 多 维 数组 ， 使 用 中 括号 来 包含 数组 的 索引 值 。 
数组 的 索引 值 由 0 开始 算 起 。 

(1) 下 列 代码 声明 变量 $a 是 一 维 数组 。 

S$a[0] = 1; 


$a[1] = 2; 
$a[2] = 3; 


(2) 也 可 以 将 上 述 代 码 改 写成 : 
$al] = 1; 
$al] = 2; 
$al] = 3; 
在 程序 执行 过 程 中 ，PHP 会 自动 将 $a[] 数 组 第 一 个 元 素 的 索引 值 由 0 开始 算 起 ， 索 引 
值 每 次 加 1。 程 序 设 计 人 员 可 以 在 程序 代码 中 任意 增加 数组 的 长 度 ，PHP 会 自动 计算 适当 
的 索引 值 。 
(3) 在 PHP 中 可 以 用 专用 的 函数 array0 来 建立 数组 。 例 如 : 
$x = array(1, 2, 3); 


表示 将 建立 一 个 一 维 数组 ， 其 中 数组 的 第 一 个 元 素 是 1， 第 二 个 元 素 是 2， 第 3 个 元 素 
是 3， 元 素 间 以 逗号 来 分 开 。 
(4) 还 可 以 将 数组 中 的 元 素 设置 成 一 个 数组 。 例 如 : 
$A1 = array(1, 2, 3); 
$A2 = array(4, 5, 6); 
$A3 = array(7, 8, 9); 
$X = array($Ax1, $A2, $A3); 
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这 样 ， 数 组 8X 相当 于 是 由 3 个 一 维 数组 SA1、$A2、$A3 构成 的 一 个 三 维 数 组 ， 其 内 
容 如 下 : 


S$X[0] [0] =1 S$X[0] [1] = 2 $X[0] [2] = 3 
S$X[1] [0] = 4 S$X[1] [1]=5 $X[1] [2] =6 
$X[2] [0] =7 S$X[2] [1] = 8 $X[2] [2] = 9 


(5) 一 般 情况 下 ，PHP 的 数组 索引 值 默认 是 以 0 开始 ， 但 程序 设计 员 可 以 在 array 函 
数 中 添加 参数 来 改变 索引 值 的 起 点 ， 如 下 面 声 明 的 数组 的 索引 值 是 从 1 开始 的 。 


S$Y1 = array(1=> "First", "Second", "Third", "Forth", "Fifth", "Sixth", "Seventh ); 


(6) 可 以 使 用 “key => value”( 键 值 => 数值 ) 的 形式 来 指定 数组 中 的 元 素 ， 例 如 : 


$a = array( 
'Class' => '09112 likey 等 于 'Class' 
'name' => 'John', /key 等 于 "name 
'Sex' => 'F', /ikey 等 于 ' Sex' 
'age' => '20"', /key 等 于 "age 
14 //key 等 于 0 
上 


echo $a['Class],"<br>"; 
echo $a[name']"<br> "; 
echo $a['Sex],"<br>"; 
echo $a[' age],"<br>"; 
echo $a[0]; 


以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 3-14 所 示 。 


[hy /oerlhos /TI Vos ource/ reoys ttncnt TiO 


GO /er er -omrs + x Ds 
上 立 位 四 “加 手包 查看 入 收藏 夫 信 工 具 开 】 坟 且 人 
Rh /aveulosvnrtodaoacewyrwstse | | 


厂 卫 eet 


图 3-14 数组 数据 类 型 的 举例 
3.2.7 ”对 象 数据 类 型 


与 Ct+、Java、C# 等 面向 对 象 编程 语言 类 似 ， 在 PHP 中 声明 一 个 对 象 之 前 ， 必 须 先 
使 用 class 关键 字 来 定义 一 个 类 ， 然 后 再 使 用 new 运算 符 来 建立 这 个 类 的 对 象 。 
(1) 下 列 代码 声明 了 一 个 类 student。 


class student 


{ 
var $name; 
Var $sex; 


var $class_id; 

var $NO; 

var $grade_maths; 

var $grade_english; 
function gettotoalgrade() 


{ 


return $this-> grade_maths +$this-> grade_english; 
} 
(2) 使 用 var 关键 字 来 声明 类 的 成 员 变 量 , 使 用 function 关键 字 来 声明 类 的 成 员 方法 。 
(3) 在 声明 student 类 的 一 个 对 象 时 , 需要 使 用 new 运算 符 来 建立 student 类 的 一 个 实 
例 (instance) 。 对 象 就 是 类 的 一 个 实例 。 
(4) 下 列 代码 声明 了 student 类 的 一 个 对 象 stu_zhang。 


$stu_zhang = new student(); 
(5) 要 存 取 对 象 的 成 员 变 量 时 ， 使 用 下 列 方式 。 


$stu_zhang->name = " 张 三 "; 

$ stu_zhang ->sex = " 男 "; 

$ stu_zhang -> class_id ="09111'; 

$ stu_zhang -> grade_maths = 68; 

$ stu_zhang -> grade_english = 86; 
print $ stu_zhang -> gettotoalgrade (); 


使 用 对 象 名 称 ， 后 面 加 上 一 个 “->” 符 号 ， 再 加 上 类 的 成 员 变量 或 成 员 方 法 的 名 称 可 
以 指向 这 个 成 员 变 量 或 成 员 方 法 。 


< 注意 : 在 对 象 名 称 的 前 面 已 经 有 5 符号， 所 以 成 员 变量 名 称 的 前 面 不 需要 再 加 上 9$ 符 号 。 
(6) 如 果 要 存 取 同一 类 中 的 成 员 变 量 ， 可 以 使 用 this 关键 字 来 代表 类 本 身 。 例 如 : 
function gettotoalgrade() { return $this-> grade_maths * $this-> grade_english; } 


在 gettotoalgrade() 函 数 中 的 $this->grade_maths 就 是 成 员 变 量 $grade_maths 的 值 , Sthis-> 
grade_english 就 是 成 员 变 量 $grade_english 的 值 。 

将 以 上 相关 代码 进行 综合 , 可 得 到 一 个 计算 学 生 张 三 的 数学 和 英语 成 绩 之 和 的 PHP 程 
序 示例 。 


class student 

d 

var $name; 

Var $sex; 

var $class_id; 

var $NO; 

var $grade_maths; 

var $grade_english; 
function gettotoalgrade() 
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{ 
return $this-> grade_maths +S$this-> grade_english; 

} 
} 
$stu_zhang = new student(); 
$stu_zhang->name = " 张 三 "; 
$stu_zhang->sex = " 男 "; 
$stu_zhang-> class_id = ‘09111’; 
$stu_zhang-> grade_maths = 68; 
$stu_zhang-> grade_english =86; 
print $stu_zhang->gettotoalgrade(); 


以 上 程序 代码 在 浏览 器 中 的 执行 结果 如 图 3-15 所 示 。 


1 文 任 四 。 编 梧 世 ) 查看 Y) 收藏 天 WW) 工具 可) 本 助人 
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图 3-15 对象 数据 类 型 的 举例 
3.2.8 资源 数据 类 型 


PHP 从 4.0 版 开始 增加 了 一 种 新 的 数据 类 型 一 一 资源 〈resource) 数据 类 型 。 这 种 变量 
用 来 参考 到 外 部 的 资源 。 例 如 ， 取 得 XML 前 析 器 、MySQL 数据 库 以 及 外 部 文件 等 。 
PHP 具有 垃圾 回收 的 功能 ， 所 以 它 会 自动 去 除 不 再 使 用 的 资源 的 内 存 。 


3.2.9 NULL 数据 类 型 


NULL 数据 类 型 的 值 只 能 是 NULL, 这 意味 着 变量 的 值 就 是 NULL, 没有 其 他 的 值 。 例 如; 
$x = NULL; 

在 PHP 中 ， 变 量 的 值 如 果 是 NULL， 主 要 有 以 下 几 种 情况 : 

口 变量 被 指定 为 NULL。 

口 ” 变 量 还 没有 指定 任何 的 数值 。 

口 变量 使 用 unset0 函 数 取消 了 原先 变量 的 赋值 。 


3.3 PHP 的 变量 与 常数 


变量 是 编程 语言 的 基础 ，PHP 的 变量 声明 ， 是 以 $ 符 号 加 上 变量 名 称 所 组 成 的 。 变 量 名 
称 是 由 英文 字母 或 下 划 线 符号 来 开头 ， 之 后 是 不 限 长 度 的 字母 、 数 字 或 下 划 线 符 号 ， 但 不 
可 以 有 空格 。 与 变量 不 同 的 是 ， 常 数 一 旦 设置 ， 在 程序 运行 期 间 就 不 能 再 改变 或 清除 。 
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3.3.1 变量 的 定义 与 赋值 


变量 具有 名 称 、 数 据 类 型 和 值 ， 变 量 值 在 程序 运行 期 间 可 以 改变 ，PHP 变量 能 够 赋予 
不 同类 型 的 数据 ， 包 括 数 值 、 字 符 串 、 布 尔 值 、 对 象 、 数 组 等 。 

下 列 代码 声明 了 一 个 变量 Sx， 该 变量 的 值 等 于 1， 并 且 系 统 会 自动 将 变量 $x 当 作 数值 
型 变量 处 理 。 例 如 : 

S$x = 1; 


下 列 代码 声明 了 一 个 变量 $Hello， 该 变量 的 值 等 于 "Welcome"， 同 样 系统 也 会 自动 将 
变量 $Hello 当 作 字 符 串 变量 处 理 。 例 如 : 


$Hello = "Welcome"; 

PHP 将 大 小 写 不 同 的 变量 名 称 视 为 不 同 的 变量 , 例如 ，$New、Snew 与 SnEw 是 不 同 的 
变量 。 如 前 所 述 ，PHP 的 变量 不 需要 事先 声明 数据 类 型 ， 而 是 直接 在 程序 代码 中 声明 变量 
名 称 与 变量 的 数值 。 例 如 : 

$x = 5; // 声 明 变量 $x 是 一 个 数字 

$str = "welcome to chengdu"; // 声 明 变量 $str 是 一 个 字符 串 
他 注意 : PHP 变量 的 数据 类 型 可 以 在 程序 代码 运行 过 程 中 任意 变换 ，PHP 会 依照 变量 所 保 

存 的 内 容 来 决定 它 的 数据 类 型 。 例 如 ， 下 列 代码 将 变量 $x 的 数据 类 型 由 数字 类 型 


转换 成 字符 串 类 型 : 
$x = 1; /此 时 ，$x 是 一 个 数字 
$x = "Washton"; // 此 时 ，$x 是 一 个 字符 串 


3.3.2 ”变量 的 参考 指定 


如 果 要 将 一 个 变量 $y 的 值 指定 给 另 一 个 变量 $x, 可 以 写成 以 下 语句 形式 :“S$y = 1;$x = 
$y;”。 这 一 程序 代码 只 是 将 变量 $y 的 值 指定 给 变量 $x， 变 量 $x 与 $y 之 间 没 有 任何 关系 。 
也 就 是 说 ， 当 变量 $y 的 值 改变 时 ， 变 量 $x 不 会 跟着 改变 。 下 面 举例 说 明 。 

建立 两 个 变量 $x 与 Sy， 设 置 8y 的 值 为 1， 将 变量 $y 的 值 指定 给 变量 8x， 显示 一 次 变量 
$x 与 $y 的 值 。 然 后 将 $y 的 值 改 成 100， 再 显示 一 次 变量 $x 与 $y 的 值 。 代 码 如 下 : 

<?php 

$y=1; 

$x = $y; 

print "在 修改 y 的 数值 之 前 x = $x, y = $y <br />"; 

$y = 100; 

print "在 修改 y 的 数值 之 后 x = $x, y = $y"; 


Ye 
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程序 运行 结果 如 图 3-16 所 示 。 

如 果 想 让 变量 $x 的 值 跟着 变量 $y 的 值 发 生 改变 ， 在 C 语言 中 可 以 使 用 地 址 引用 
在 PHP 语言 中 ， 应 使 用 变量 的 参考 指定 (assign by reference) 。 例 如 : 

$y=1; 

$x = &$y; 

上 述 代 码 中 ,在 变量 $y 的 前 面 加 上 & 符 号 ,表示 变量 $y 在 内 存 中 的 地 址 ,语句 “$x = &$y;” 
表示 变量 $x 指向 变量 $y 的 内 存 地 址 。 所 以 当 变 量 $y 的 值 改变 时 ， 变 量 $x 就 会 跟着 改变 。 

建立 两 个 变量 $x 与 Sy, 设置 $y 的 值 等 于 1， 将 变量 $y 的 值 使 用 参考 指定 给 变量 $x， 显 
示 一 次 变量 $x 与 $y 的 值 。 然 后 将 $y 的 值 改 成 100， 青 显示 一 次 变量 $x 与 $y 的 值 。 


<?php 

$y=1; 

$x = &$y; 

print "在 修改 y 的 数值 之 前 x = $x, y = $y <br />"; 
$y = 100; 

Print "在 修改 y 的 数值 之 后 x = $x, y = $y"; 
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以 上 程序 的 执行 结果 如 图 3-17 所 示 。 
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图 3-16 变量 值 的 指定 图 3-17 给 变量 赋值 


3.3.3 ”常数 的 声明 


在 现实 生活 中 ， 有 一 些 数 是 固定 不 变 的 ， 如 圆周 率 、 光 速 、 一 年 中 的 月 数 等 。 这 些 固 
定 不 变 的 数 在 程序 设计 中 称 为 常数 ， 常 数 一 经 定义 就 固定 不 变 。 在 PHP 程序 中 ， 通 常 使 用 
define() 函 数 来 声明 常数 。 例 如 ， 下 列 代 码 定义 了 常数 PI 的 值 是 3.14159。 


define("PI", 3.14159); 

下 列 代码 定义 了 常数 “字符 串 1” 的 值 是 “中 国人 民 ” 

Define(" 字 符 串 1", "中 国人 民 "); 

某 些 情况 下 ， 当 常数 名 被 保存 到 变量 中 或 是 由 函数 返回 时 ， 程 序 员 可 能 并 不 清楚 这 个 
变量 存放 的 就 是 自己 所 需要 的 常数 ， 这 时 ， 就 要 用 到 constant0 函 数 。 如 下 例 所 示 : 


define(ISBN, "9781233432"); 
S$value=constant(ISBN) // 将 返回 9781233432 
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3.3.4 保留 字 


与 C 语言 一 样 ，PHP 有 一 些 内 定 的 保留 字 ， 不 能 用 来 当 作 常 数 、 类 或 是 函数 的 名 称 。 
因为 是 使 用 $ 符 号 来 开头 ， 所 以 可 以 使 用 保留 字 ， 但 最 好 不 要 使 用 。 
PHP 常见 的 保留 字 有 : and、or、xor、_FILE 、exception、_LINE 、array0、as、break、 


case、 cfunction、class、const、continue、declare、default、die()、do、echo()、else、elseif、 


Ell 


变 


empty()、enddeclare、endfor、endforeach、endif、 ndswitch、endwhile、eval、exit()、extends、 
for、 foreach、 function, global, if\ include(), include_ ince(), isset()、 list()、 new、 old_function、 
print(O)\require()\ require_once()\retum(), static, switch、 unset()\use、var、 while、FUNCTION 、 
_CLASS 、_METHOD 、php user filter。 


3.3.5 ”可 变 变 量 (动态 变量 ) 


可 变 变 量 又 称 为 动态 变量 ， 其 名 称 被 保存 在 另 一 个 变量 中 。 也 就 是 说 ， 可 变 变量 以 另 
外 一 个 变量 的 数值 作为 它 的 变量 名 称 。 

普通 变量 的 声明 形式 为 “$x = "hello"”， 而 可 变 变量 的 声明 形式 需要 通过 两 个 “$” 符 
号 来 定义 。 例 如 : 

$x = "hello"; 

$$x = "world"; 

print "$x $hello"; 

其 中 ，print 语句 的 功能 与 echo 语句 类 似 ， 负 责 在 屏幕 上 打印 相关 信息 。 

上 述 代码 实际 上 定义 了 两 个 变量 ， 变 量 $x 的 值 为 "hello"， 变 量 $hello 的 值 为 "world"， 
变量 $hello 就 等 于 $$x。 在 浏览 器 中 查看 执行 结果 ， 如 图 3-18 所 示 。 

如 果 使 用 print 语句 来 输出 下 列 代码 : 

print "$x ${$x} ; 


也 会 得 到 : hello world。 
但 是 如 果 使 用 print 语句 来 输出 下 列 代码 : 
print "$x $$x"; 


则 会 得 到 : hello $Shello。 这 是 因为 $x = "hello"， 所 以 print 将 $8x 输出 为 $hello。 

所 以 ， 要 保证 输出 的 正确 性 ， 必 须 用 大 括号 将 原先 的 变量 包含 起 来 ， 如 语句 “print "$x 
${$x}";” 所 示 。 

如 将 变量 $x 的 值 设置 为 "hello"， 使 用 可 变 变量 将 $x 的 值 "hello" 设 置 为 另外 一 个 变量 
$hello = "world"。 分 别 输出 "$x $$x"、"$x ${$x}" 与 "$x $hello" 的 值 。 

<?php 


$x = "chinese"; 
$$x = "man"; 
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print "$x $$x" . "<br />"; 
print "$x ${$x}" . "<br />"; 
print "$x $chinese"; 

Re 


结果 如 图 3-19 所 示 。 


[Shttp //1ocalhost/PIPhe oks onr ce rr 1 -Iolxl 
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图 3-18 可 变 变 量 (1) 


厂矿 导 Itemet 


图 3-19 可 变 变 量 (2) 


PHP 提供 了 很 多 运算 符 ， 能 够 对 各 种 数据 对 象 进行 多 种 不 同类 型 的 操作 。 运 算 符 可 以 
通过 给 出 的 一 个 或 多 个 值 〈 而 这 一 个 或 多 个 值 就 构成 了 表达 式 ) 产生 另 一 个 值 ， 所 以 可 以 
认为 函数 或 任何 会 返回 一 个 值 的 结构 都 是 运算 符 。 例 如 ， 在 表达 式 “4+6” 中 ，4 和 6 是 操 


作 数 ， 而 “+” 是 操作 符 ， 也 称 运算 符 。 


PHP 支持 3 种 类 型 的 运算 符 。 第 一 种 是 一 元 运算 符 ， 只 运算 一 个 值 ， 如 ! 运 算 符 〈 取 反 
运算 符 ) 或 + 运算 符 ( 加 一 运算 符 ) 。 第 二 种 是 有 限 二 元 运算 符 ，PHP 支持 的 大 多 数 运算 
符 都 是 这 种 。 第 三 种 是 三 元 运算 符 ， 如 “条 件 表达 式 ? 表 达 式 1: 表 达 式 2”， 用 来 根据 条 件 
表达 式 的 值 ， 在 另 两 个 表达 式 中 选择 一 个 作为 整个 运算 的 结果 。 


3.3.6 ”运算 符 优先 级 


运算 符 优先 级 指定 了 两 个 表达 式 绑 定 得 “紧密 ” 


程度 。 例 如 ， 表 达 式 1+5*3 的 结果 是 


16 而 不 是 18， 是 因为 乘 号 〈*#) 的 优先 级 比 加 号 (+) 高 。 必 要 时 ， 可 以 用 括号 来 强制 改变 
优先 级 。 例 如 ，(1+5)*3 的 值 为 18。 如 果 运 算 符 的 优先 级 相同 ， 则 从 左 到 右 依次 进行 运算 。 
表 3-3 从 高 到 低 列 出 了 所 有 运算 符 的 优先 级 。 同 一 行 中 的 运算 符 具 有 相同 优先 级 ， 此 


时 它们 的 结合 方向 决定 求 值 顺序 。 


表 3-3 运算 符 的 优先 级 


运 算 符 描述 结合 方向 

0 小 括号 左 到 右 
new 创建 对 象 非 结 合 
数组 下 标 左 到 右 
和 递增 /递减 运算 符 非 结 合 
A 逻辑 非 、 位 运算 非 、 求 反 非 结合 
(int) (float) (string) (array) (object) 强制 指派 数据 类 型 非 结合 

抑制 错误 非 结 合 
* /0% 算术 运算 符 〈 乘 法 、 除 法 、 取 模 ) 左 到 右 
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续 表 
运 算 符 描 述 结合 方向 

十 一 . 加 法 、 减 法 ， 字 符 串 串 连 左 到 右 
<<>> 位 运算 符 〈 向 左 移 位 、 向 右 移 位 )》 左 到 右 
<<=>>= 比较 运算 符 ( 小 于 、 小 于 等 于 、 大 于 、 大 于 等 于 ) 非 结合 
= 性 比较 运算 符 〈 等 于 、 不 等 于 ) 非 结 合 
= 一 ! 一 比较 〈 对 象 ) 运算 符 ( 等 同 、 不 等 同 ) 非 结合 
& 位 运算 符 (与) 和 引用 左 到 右 
A 位 运算 符 ( 异 或 ) 左 到 右 
| 位 运算 符 或 ) 左 到 右 
C& 逻辑 运算 符 (与 ) 左 到 右 
| 逻辑 运算 符 (或 ) 左 到 右 
于: 三 元 运算 符 左 到 右 
= 二 一 导 广 =%&= 上 生 <<=>>= | 赋值 运算 符 右 到 左 
and 逻辑 运算 符 (与 ) 左 到 右 
xor 逻辑 运算 符 〈( 异 或 ) 左 到 右 
or 逻辑 运算 符 (或 ) 左 到 右 
，( 逗 号) 列表 分 隔 符 等 左 到 右 


在 表 3-3 的 结合 方向 一 栏 中 ，“ 左 到 右 ” 表 示 表 达 式 从 左 向 右 求 值 ，“ 右 到 左 ” 表 示 
表达 式 从 右 向 左 求 值 。 为 理解 各 种 运算 符 的 优先 级 顺序 ， 不 妨 举例 如 下 : 


<?php 

$a=3*3%5,; //(3*3)%5=4 

echo $a,"<br>"; 

$a=true ?0:true?1:2; l(true ? 0 :true)?1:2=2 

echo $a,"<br>"; 

$a=1; 

$b = 2; 

$a = $b += 3; /相当 于 $a = ($b += 3),$a = 5,$b=5 
echo $a,"<br>"; 

?> 


文件 中。 久 入 四、 查看 收藏 天 工具 中) 帮助 0 
窑 路 本 天 。 逢 http 1/1localhesV/PiEbooksoaree/eperstecoa | 


le ss /oc 


图 3-20 运算 符 优先 级 举例 


SS 
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3.3.7 算术 运算 符 


在 初等 数学 中 ， 常 见 到 有 加 减 乘除 等 运算 ，PHP 中 算术 运算 符 就 与 此 类 似 ， 往 往 是 以 
数值 (变量 或 数字 〉 作 为 操作 数 ， 并 且 返 回 单一 的 数值 ， 如 表 3-4 所 示 。 


表 3-4 PHP 算术 运算 符 列表 


$a 的 负 值 
$a 和 $b 的 和 
$a 和 $b 的 差 
$a 和 $b 的 积 

$a 除 以 $b 的 商 
$a % $b $a 除 以 $b 的 余数 


< 全 注意 : 除法 运算 (“/”) 总 是 返回 浮上 点数， 即使 两 个 运算 数 是 整数 (或 由 字符 串 转换 成 
的 整数 ) 也 是 这 样 。 例 如 : 


<html> 
<head> 
<title></title> 
</head> 
< body> 
<?php 
$data1=5; 
$data2=9; 
$sum=$data1+$data2; 
print "<h3>$sum=$data1+$data2<br/>"; 
S$sum=$sum+(10/2+5)%7; 
print "$sum=14+(10/2+5)%7<br/></h3>"; 
?> 
</body> 
</html> 


以 上 程序 在 浏览 器 中 的 执行 结果 如 图 3-21 所 示 。 


文件 四” 编 辑 吕 查看 WD 收 蕊 严 Q) 工具 UT) 帮助 0 
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图 3-21 算术 运算 符 举例 


S6 


第 3 章 PHP 的 基本 语法 


3.3.8 ”赋值 运算 符 


基本 的 赋值 运算 符 是 “=”。 初学 者 一 开始 可 能 把 它 当 作 “ 等 于 ”, 但 实际 上 它 的 功能 
是 把 右边 表达 式 的 值 赋 给 左边 的 操作 数 。 例 如 : 

<? php 

$a= ($b=4)+5; //$a 现在 成 了 9， 而 $b 成 了 4 


?> 


在 基本 赋值 运算 符 之 外 ， 还 有 适合 于 二 元 算术 、 数 组 集合 和 字符 串 运 算 符 的 “组 合 运 
算 符 ”。 例 如 : 

<?php 

$a=3; 

$a += 5; // 运 用 了 短路 运算 符 

$b = "Hello "; 


$b .= "Therel"; 
?> 


其 中 ， 在 表达 式 “$a += 5” 中 用 到 了 短路 运算 符 “+=”。 短 路 运算 符 允 许 编程 人 员 把 
赋值 运算 符 与 一 个 算术 或 字符 运算 符合 并 在 一 起 ， 实现 算术 或 字符 操作 。 例如 ，“$a=$at5” 
可 以 写成 “$at=5”。 


< 所 注意 : 赋值 运算 是 将 原 变量 的 值 复制 到 新 变量 中 ( 传 值 赋值 )， 所 以 改变 其 中 一 个 并 不 
影响 另 一 个 。 这 也 适合 于 在 很 密集 的 循环 中 复制 一 些 值 ， 如 大 数组 。 自 PHP 4 
起 支持 引用 赋值 ， 如 $var= 多 $othervar， 但 在 PHP 3 中 不 可 能 这 样 做 。 引 用 赋值 
意味 着 两 个 变量 都 指向 同一 个 数据 ， 没 有 任何 数据 的 拷贝 。 


3.3.9 位 运算 符 


众所周知 ，“ 位 ”是 计算 机 世界 中 最 小 的 信息 单位 ， 每 一 个 数据 在 计算 机 内 部 都 最 终 
表现 为 由 0 和 1 组 成 的 二 进 制 位 代码 。 位 运算 符 允 许 对 整 型 数 中 指定 的 位 进行 置 位 ， 如 
表 3-5 所 示 。 如 果 左 右 参 数 都 是 字符 串 ， 则 位 运算 符 将 操作 其 字符 所 对 应 的 ASCII 码 值 。 
全) 注意 : 在 32 位 系统 上 不 要 右 移 超过 32 位 ， 不 要 在 结果 可 能 超过 32 位 的 情况 下 左 移 。 

表 3-5 ”位 运算 符 的 应 用 规则 

范例 含义 

$a& Sb | 将 把 Sa 和 $b 中 都 为 1 的 位 设 为 1 

$a | Sb 将 把 $a 或 者 $b 中 为 1 的 位 设 为 1 
将 把 $a 和 $b 中 不 同 的 位 设 为 1 

~ $a 将 $a 中 为 0 的 位 设 为 1， 反 之 亦 然 

$a << $b | 将 $a 中 的 位 向 左 移动 $b 次 (每 一 次 移动 都 表示 “ 乘 以 2”) 

$a >> $b | 将 $a 中 的 位 向 右 移动 $b 次 (每 一 次 移动 都 表示 “ 除 以 2”) 
把 二 进 制 表示 的 x 向 右 移动 y 位 ,抛弃 移出 的 位 ， 并且 从 左 
侧 移 进 0 


X>>>y 


SI 
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如 下 例 : 


<?php 

echo 12^9; 
echo "12" ^ "9"; 
?> 


在 第 1 行 中 ，PHP 进行 异 或 运算 ， 将 12 转换 为 1100， 将 9 转 为 1001， 然 后 用 1001 
对 1100 进行 重新 置 位 得 出 0101， 即 输出 为 '5'。 

在 第 2 行 中 ,PHP 也 是 进行 异 或 运算 ,此 时 ,系统 将 取 字 符 串 "12" 中 的 首 字符 1 的 ASCII 
值 即 49， 然 后 与 9 的 ASCII 码 值 即 57 进行 位 运算 ， 得 到 8 即 空格 符 的 ASCII 码 值 ， 所 以 
此 行将 输出 空格 。 


3.3.10 ”递增 /递减 运算 符 


PHP 支持 C 语言 的 前 /后 递增 与 递减 运算 符 。 需 要 注意 的 是 ， 递 增 / 递 减 运算 符 不 影响 
布尔 值 ， 北 减 NULL 值 没 有 效果 ， 但 是 递增 NULL 后 的 结果 是 1， 如 表 3-6 所 示 。 
表 3-6 递增 /递减 运算 符 的 应 用 规则 


运 算 符 所 完成 的 操作 
++$a $a 的 值 加 1， 然 后 返回 $a 
$a++ 返回 Sa， 然后 将 $a 的 值 加 1 
一 $a $a 的 值 减 1， 然 后 返回 $a 
$a 一 返回 $a， 然 后 将 $a 的 值 减 1 
下 面 通过 实例 来 帮助 读者 理解 递增 /递减 运算 符 。 
<?php 
echo "<h3> 后 加 操作 </h3>"; 
$a=5; 


echo "此 次 结果 应 该 是 5: ". $a++ . "<br />\n"; 
echo "此 次 结果 应 该 是 6: " . $a . "<br />\n"; 
echo "<h3> 先 加 操作 </h3>"; 

$a = 5; 

echo "此 次 结果 应 该 是 6: " . ++$a . "<br />\n"; 
echo "此 次 结果 应 该 是 6: " . $a . "<br />\n"; 
echo "<h3> 后 减 操作 </h3>"; 

$a=5; 

echo "此 次 结果 应 该 是 5: " . $a-- . "<br />\n"; 
echo "此 次 结果 应 该 是 4: ". $a . "<br />\n"; 
echo "<h3> 先 减 操作 </h3>"; 

$a=5; 

echo "此 次 结果 应 该 是 4: " . --$a . "<br />\n"; 
echo "此 次 结果 应 该 是 4: ". $a . "<br />\n"; 
?> 


以 上 程序 代码 在 浏览 器 中 的 执行 结果 如 图 3-22 所 示 。 
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图 3-22 递增 /递减 运算 符 举 例 
3.3.11 ”逻辑 运算 符 
风 辑 运算 符 用 来 测试 数据 之 间 的 真 假 值 ， 经 常用 在 条 件 判 断 和 循环 处 理 中 ， 以 此 判断 
条 件 是 否 满足 以 及 是 否 该 结束 循环 或 继续 执行 。PHP 的 逻辑 运算 符 主要 有 6 种 ， 如 表 3-7 


表 3-7 逻辑 运算 符 的 应 用 规则 


， 如 果 $a 与 $b 都 为 TRUE 
， 如 果 $a 或 $b 任 一 为 TRUE 
xor (逻辑 异 或 ) ， 如 果 $a 或 $b 任 一 为 TRUE， 但 不 同时 是 

， 如 果 $a 不 为 TRUE 

， 如 果 $a 与 $b 都 为 TRUE 

， 如 果 $a 或 $b 任 一 为 TRUE 

< 注意 : 远 辑 与 和 逻辑 或 有 两 种 不 同形 式 的 运算 符 ， 但 它们 的 功能 是 不 同 的 ， 原 因 在 于 
它们 运算 的 优先 级 不 同 。 


3.3.12 ”字符 串 运 算 符 


PHP 中 有 两 个 字符 串 运 算 符 。 一 个 是 连接 运算 符 〈.) ， 它 返回 其 左右 参数 连接 后 的 字 
符 串 。 另 一 个 是 连接 赋值 运算 符 (=) ， 它 将 右边 的 参数 附加 到 左边 的 参数 后 。 例 如 : 


<?php 

$a = "Hello "; 

$b = $a . "World!; /此 时 ，$b 包含 了 "Hello World" 
$a = "Hello "; 

$a .= "World!"; // 将 Hello 与 World 拼接 起 来 
echo "<center>".$a."</center>"; 

?> 
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以 上 程序 代码 运行 后 的 结果 如 图 3-23 所 示 。 


」 文件 人 ”编辑 中 查看 收 总 天 WW) 工具 QD 帮助 opD 
这 收 着 夹 其 http://localhost/PiPbooksource/hellororld .. 


Hello World! 


TT me 
图 3-23 字符 串 运算 符 举 例 


3.3.13 ”强制 类 型 转换 运算 符 


PHP 最 大 的 特点 是 对 数据 类 型 的 约束 比较 宽松 ， 也 就 是 说 ， 程 序 员 可 以 不 必 关 心 变量 
中 存储 的 是 什么 类 型 的 数据 。 例 如 ， 在 一 行 代码 中 可 以 将 $y 赋予 一 个 数值 ， 而 在 另 一 行 代 
码 中 将 $y 赋予 一 个 字符 串 。 多 数 情况 下 ，PHP 能 自动 实现 必要 的 类 型 转换 。 但 有 时 ， 也 需 
要 强制 性 地 把 一 种 类 型 转换 成 另 一 种 类 型 ， 这 就 是 下 面 要 讲 的 强制 类 型 转换 。 

PHP 中 的 类 型 强制 转换 和 C 语言 非常 类 似 ， 只 需 在 要 转换 的 变量 之 前 加 上 用 括号 括 起 
来 的 目标 类 型 即 可 。 

允许 进行 强制 类 型 转换 的 数据 类 型 如 下 所 示 : 

口 (inb、(integeD: 强制 转换 成 整 型 。 

口 (booD)、(boolean): 强制 转换 成 布尔 型 。 

口 ”(float)、(double)、(real): 强制 转换 成 浮 点 型 。 

口 (string): 强制 转换 成 字符 串 。 
口 
可 | 


(array): 强制 转换 成 数组 。 
(object): 强制 转换 成 对 象 。 

还 可 以 用 settype(mixed var, string type) 进 行 强制 转换 。 需 要 注意 的 是 , 绝 不 要 将 未 知 的 
分 数 强制 转换 为 integer， 这 样 有 时 会 导致 错误 的 结果 。 下 面 通过 实例 来 理解 强制 转换 运 


<?php 


echo (int) ((0.1+0.7) * 10); // 将 显示 7 
$str = "123.456abc7"; 

echo (int)$str; /将 显示 123 
$str = "abc123.456"; 

echo (int)$str; // 将 显示 0 
$str = true; 

echo (int)$str; /将 显示 1 
$str = false; 

echo (int)S$str; /将 显示 0 
?> 
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3.3.14 ”执行 运算 符 


PHP 支持 一 个 执行 运算 符 : 反 引 号 “”。 其 外 观 像 单 引 号 “”， 但 其 实 不 是 。PHP 
会 尝试 将 反 引号 中 的 内 容 作 为 操作 系统 命令 来 执行 ， 并 将 其 输出 信息 返回 ， 还 可 以 将 值 
赋 给 一 个 变量 。 使 用 反 引 号 运算 符 “`” 的 效果 与 使 用 PHP 内 置 函数 shell_ exec0O 的 效果 
相同 。 


< 注意 : 反 引 号 中 的 具体 内 容 取决 于 实际 使 用 的 操作 系统 。 如 在 Windows 环境 下 执行 如 
下 程序 代码 ， 将 在 浏览 器 中 查看 到 当前 网 页 的 存放 目录 ， 如 图 3-24 所 示 。 


<?php 

$output = "dir ; 

echo "<pre>$output</pre>"; 
?> 


[http://1locelhost /PPbooksoarce/zhizingc rE pi2 i 
(Ce 

」 文件 中) 蝙 辑 世 ) 查看 W) 路 康夫 工具 帮助 QD) 

路 计 夹 。 赔 http://1ocslhosuPIEbookaosree/ zhixingsxf 


驱动 器 D 中 的 卷 设 有 标签 。 
泡 的 序列 号 是 4530-7885 
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图 3-24 ”执行 运算 符 举 例 
3.3.15 ”PHP 语言 表达 式 


PHP 表达 式 是 由 运算 符 、 操 作 数 以 及 括号 等 所 组 成 的 合法 序列 代码 ， 是 PHP 程序 最 重 
要 的 基石 。 在 PHP 中 ， 几 乎 所 有 的 代码 组 合 就 是 一 个 表达 式 。PHP 与 其 他 语言 相 比 ， 其 表 
达 式 的 构成 更 丰富 、 更 灵活 、 功 能 也 更 强 。 

最 基本 的 表达 式 由 常量 和 变量 构成 ， 如 “$a = 7”， 即 表示 将 值 “7” 分 配给 变量 $a。 

根据 表达 式 中 运算 符 的 作用 不 同 ， 可 把 表达 式 分 为 算术 表达 式 、 赋 值 表达 式 、 字 符 串 
表达 式 、 位 运算 表达 式 、 逻 辑 表达 式 和 比较 表达 式 等 。 还 有 一 种 特殊 的 表达 式 ， 即 三 元 条 
件 运 算 符 的 表达 式 ， 其 形式 为 “$ 表 达 式 1 ? $ 表 达 式 2 : $ 表 达 式 3”。 该 表达 式 由 3 个 子 表 
达 式 构成 ， 其 功能 是 : 如果 表 达 式 1 的 值 是 TRUE， 那 么 计算 表达 式 2 的 值 ， 将 其 值 作为 
整个 表达 式 的 值 ， 否 则 ， 表 达 式 3 的 值 将 作为 整个 表达 式 的 运行 结果 。 
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3.4 PHP 程序 中 的 流程 控制 
任何 程序 都 不 外 乎 有 3 种 程序 结构 ， 即 顺序 结构 、 分 支 结构 和 循环 结构 。 程 序 由 若干 
语句 组 成 ， 顺 序 结 构 中 语句 按 先后 顺序 逐条 执行 ， 不 存在 分 支 和 循环 。 顺 序 结 构 是 最 基本 
也 最 常见 的 流程 结构 ， 这 里 就 不 再 袭 述 。 
下 面 重点 来 讲解 分 支 结构 和 循环 结构 。 


3.4.1 if…else 语句 


if…else 语句 的 功能 是 : 满足 某 个 条 件 时 执行 语句 1 或 语句 块 1， 不 满足 该 条 件 时 执行 
语句 2 或 语句 块 2。 其 基本 形式 如 下 : 
寺 (条件) 
{ 
语句 1 或 语句 块 1 ”// 条 件 为 逻辑 真 时 执行 语句 1 或 语句 块 1 


else 


语句 2 或 语句 块 2 // 条 件 不 成 立时 执行 语句 2 或 语句 块 2 
} 

如 有 以 下 语句 : 

if ($num>=0) 
echo" 非 负数 "; 


else 
echo "负数 "; 


当然 ， 如 果 只 做 单纯 的 条 件 判断 ， 则 可 去 掉 else 部 分 ， 而 只 保留 陡 条 件 判断 和 相应 的 
执行 语句 或 语句 块 : 


if( 条 件 ) 
{语句 或 语句 块 // 条 件 为 逻辑 真 时 执行 这 部 分 语句 或 语句 块 
} 


3.4.2 if.…else if 语句 


if…else 结构 只 能 实现 二 路 分 支 ， 而 于 …else 站 语句 可 实现 多 路 分 支 ， 其 基本 形式 如 下 : 
if( 条 件 1) 

{语句 1 或 语句 块 1 // 条 件 1 为 逻辑 真 时 执行 语句 1 或 语句 块 1 

} 
else 这 条 件 2) 
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语句 2 或 语句 块 2 // 条 件 2 成 立时 执行 语句 2 或 语句 块 2 
} 

else if( 条 件 3) 
语句 3 或 语句 块 3 // 条 件 3 成 立时 执行 语句 3 或 语句 块 3 
} 


例如 ， 以 下 代码 将 判断 两 数 的 大 小 关系 。 


<?php 
if ($x > $y) { 

echo "x is bigger than y"; 
} else if ($a == $b){ 

echo "x is equal to y"; 
}else{ 

echo "x is smaller than y"; 


} 

?> 

在 同一 个 if…else 结构 中 可 以 有 多 个 else 让 语句 。 在 PHP 中 ,else 站 也 可 以 写成 elseif， 
两 者 的 效果 完全 一 样 。 


3.4.3 ”while 循环 结构 


while 循环 是 PHP 中 最 简单 的 循环 类 型 。 它 和 C 语言 中 的 while 表现 形式 一 样 ， 其 基 
本 格式 如 下 : 
while( 表 达 式 ) 。 “// 先 判断 循环 条 件 ， 青 执行 循环 体 


{ 
语句 或 语句 块 ; 
} 
while 循环 结构 中 ， 只 要 while 表达 式 的 值 为 TRUE， 就 重复 执行 循环 体 中 的 语句 或 语 
句 块 ， 如 果 while 表达 式 的 值 一 开始 就 是 FALSE， 则 循环 体 中 的 语句 或 语句 块 一 次 都 不 被 
执行 。 


3.4.4 do…while 循环 结构 


do…while 和 while 循环 非常 相似 ， 区 别 在 于 do…while 循环 是 先 执行 循环 体 ， 再 判断 
循环 条 件 ， 也 就 是 说 ，do…while 循环 至 少 会 执行 一 次 循环 体 中 的 语句 或 语句 块 ， 而 while 
循环 有 可 能 一 次 都 不 执行 。 

do…while 循环 的 结构 形式 如 下 : 

do 
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{ // 先 执行 循环 体 ， 再 判断 循环 条 件 
语句 或 语句 块 

}while( 条 件 ) 

下 面 通过 实例 来 理解 以 上 两 种 while 循环 结构 的 区 别 。 


<?php 
$i=1; 
while($i<=6){ 
print $i++; 
echo ". Excuse me<br>\n"; 


print $i++; 
echo ". Excuse me <br>\n"; 
} while($i<=6) 

?> 


其 执行 结果 如 图 3.25 所 示 。 
EE htty Te 


| 文件 @ 饥 久 加” 亚 看 吕 中 本 天 由 工具 CC) 骨 助 D 
这 收 路 天 。 巷 htty://lscdhost/HhPborksou cs/rhile php 


图 3-25 两 种 while 循环 结构 的 区 别 (1) 


此 时 , 还 看 不 出 二 者 的 区 别 , 将 上 述 代码 的 第 2 行 和 第 8 行 的 $i 初始 值 修 改 为 “$i=7”， 
然后 再 在 浏览 器 中 查看 执行 结果 ， 则 如 图 3-26 所 示 。 


tn /lscalhestyTIPVenkS ie Tindews Tteraet Fs 


| 文件 至) 篇 宴 中 ”查看 Y) 收 赤 到 从 工具 TD) 部 助 0 
这 中 大 天 猴 http://loealhost/HPyookscurce/shile phy 


[mi | | i 


图 3-26 ”两 种 while 循环 结构 的 区 别 (2》) 


第 3 章 PHP 的 基本 语法 


3.4.5 for 循环 结构 


for 循环 是 PHP 中 最 复杂 的 循环 结构 ， 其 功能 和 用 途 与 C 语言 中 的 for 循环 类 似 。for 
循环 的 基本 语法 如 下 : 
for( 表 达 式 1; 表达 式 2; 表达 式 3) 
{ 
语句 或 语句 块 
} 
其 中 ， 表 达 式 1 在 循环 开始 前 无 条 件 求 值 一 次 。 表 达 式 2 在 每 次 循环 开始 前 求 值 。 如 
果 值 为 TRUE， 则 继续 执行 嵌 套 的 循环 语句 ， 如 果 值 为 FALSE， 则 终止 循环 。 表 达 式 3 在 
每 次 循环 之 后 被 执行 。 每 个 表达 式 都 可 以 为 空 ,此 时 ， 和 C 一 样 ，PHP 认为 其 值 为 TRUE， 
整个 嵌 套 语句 将 无 限 循环 下 去 。 
在 以 下 的 程序 中 ， 共 有 3 种 不 同 的 for 循环 结构 ， 它 们 都 显示 数字 1 一 10。 


<?php 
for ($i = 1; $i <= 10; $i++) 
{ 

echo $i; 


echo "<br>","Above is the first","<br>"; 
for ($i = 1;; $i++) 


if ($i> 10) 
{ 
break; // 中 止 循环 
} 
echo $i; 
} 


echo "<br>","Above is the second","<br>"; 


$i=1; 
for(;;) 


if($i > 10) 


{ 
breaki // 中 止 循环 


} 
echo $i; 
$i++; 


echo "<br>", "Above is the third","<br>"; 
?> 


以 上 代码 的 执行 结果 如 图 3-27 所 示 。 
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图 3-27 for 循环 结构 应 用 举例 
3.4.6 foreach 循环 


从 PHP 4 开始 ，PHP 引入 了 foreach 结构 ， 和 C# 以 及 其 他 语言 很 像 ， 它 是 一 种 简便 的 
遍历 数组 方法 。foreach 仅 能 用 于 数组 ， 当 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 初始 化 的 变量 
时 ， 会 产生 错误 。 

下 例 是 利用 foreach 遍历 一 个 一 维 数组 ,其 中 在 第 一 次 遍历 时 显示 数组 中 的 各 元 素 ,第 
二 次 遍历 时 将 数组 中 的 每 个 元 素 取出 ， 乘 以 2 后 再 显示 出 来 。 

<?php 


$arr = array(1, 2, 3, 4); 
foreach ($arr as &$value) 


echo $value; 
} 
echo "<br>"; 
foreach ($arr as &$value) 


S$value = $value * 2; 
echo $value; 


} 


?> 


以 上 代码 执行 后 的 结果 如 图 3-28 所 示 。 


1234 
2468 


图 3-28 foreach 循环 结构 应 用 举例 


3.4.7 break 与 continue 语句 


在 讲述 for 循环 结构 时 用 到 了 break 语句 ， 它 的 作用 是 中 途 结束 for、foreach、while、 
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do…while 循环 ， 或 者 中 止 switch 结构 的 执行 。 同 样 ，continue 语句 也 是 用 在 循环 结构 中 ， 
它 的 作用 是 跳 过 本 次 循环 中 剩余 的 代码 并 在 条 件 为 真 时 开始 执行 下 一 次 循环 。 
以 下 代码 将 演示 break 语句 和 continue 语句 的 区 别 。 


<?php 
echo "break 语句 的 输出 效果 : <br>"; 
$i=0; 
while ($i<10){ 

if ($i%2==1) { 

break; 

} 

echo $i; 

9$i++; 


1 
echo "<br>","continue 语句 的 输出 效果 : ","<br>"; 
for($i=0;$i<10;$i++){ 
if ($i962X{ 
continue; 


} 
echo $i."&nbsp;"; 
} 


?> 


在 浏览 器 中 查看 执行 结果 如 图 3-29 所 示 。 


/Shttp://1ocalhest/phy nel lin 
直人 IO | CR Sr 
这 收 荐 奕 榴 http;//localhost/phpbooksource/ continuel. php | | 
习 
break 语 句 的 输出 效果 ， 


0 
continue 语 句 的 输出 效果 ， 
02468 


图 3-29 break 与 continue 语句 的 应 用 
3.4.8 switch 语句 


一 个 switch 语句 可 以 等 同 于 一 系列 让 语句 ， 其 功能 是 : 把 一 个 变量 〈 或 表达 式 ) 与 多 
个 不 同 的 值 进行 比较 ， 并 根据 比较 结果 执行 不 同 的 程序 代码 。 
switch 语句 的 格式 如 下 : 
switch( 条 件 ) 
{ /根据 条 件 的 具体 值 来 执行 下 面 某 一 语句 
case 选项 1: 
语句 1; break; 
case 选项 2: 
语句 2; break; 
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case 选项 n: 
语句 n:; break; 
default; 
语句 ntl; 
break: 
} 
例如 ， 以 下 语句 将 根据 $i 值 的 不 同 而 显示 相应 的 数值 。 
<?php 
switch ($1) 
{ 
case 0: 
echo "i 等 于 0"; 
break; 
case 1: 
echo "i 等 于 1"; 
break; 
case 2: 
echo "i 等 于 2"; 
break; 
} 
?> 


3.5 案例 剖析 : 九 九 乘 法 口诀 表 的 实现 


本 章 最 后 将 利用 PHP 语言 编写 一 个 九 九 乘法 口诀 表 ， 使 读者 进一步 掌握 PHP 的 基础 


3.5.1 程序 功能 介绍 


输出 九 九 乘法 口诀 表 ， 使 用 任何 一 种 程序 设计 语言 都 比较 容易 实现 ， 而 且 也 是 常用 的 
经 典 案例 。 下 面 分 析 如 何 利用 PHP 实现 九 九 乘法 口诀 表 的 输出 。 
简单 地 说 ， 九 九 乘法 表 就 是 一 个 二 维 表格 ， 只 不 过 该 表格 中 每 一 行 的 乘法 表达 式 会 随 
着 行 数 的 增加 而 有 所 增加 ， 并 且 是 以 1 为 单位 逐次 递增 的 。 考 虑 到 以 上 特点 ， 下 面 简单 描 
述 一 下 程序 的 设计 思路 。 
口 设置 一 个 变量 x， 用 以 存放 乘法 表 的 行 数 ， 这 里 选择 存储 9。 
本 程序 功能 的 实现 主要 采用 内 、 外 两 层 循环 结构 实现 。 
设置 一 个 外 循环 变量 i， 用 来 控制 行 数 。 
设置 一 个 内 循环 变量 j， 用 来 控制 每 一 行 的 列 数 。 
利用 echo0 函 数 逐 一 显示 每 一 行 的 乘法 表达 式 。 


局 .已 口 已 
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3.5.2 程序 代码 分 析 
基于 九 九 乘法 表 的 特点 和 上 述 功能 分 析 ， 编 写 如 下 代码 ; 


<html> 

<head> 

<title></title> 

</head> 

<body> 
<h3><center> 九 九 乘法 口诀 表 </center></h3> 
<?php 

$x=9; 

for ($i=1;$i<=$x;$i++) 


for ($j=1;$j<=$i;$j++) 


echo $j."*".$i."=".$j*$i."&nbsp;";  //“&nbsp;” 用 于 在 浏览 器 中 输出 一 个 空格 
} 
echo "<br>"; 


» 


?> 

</body> 

</html> 

以 上 代码 为 九 九 乘法 口诀 表 的 完整 代码 , 其 中 包含 了 HTML 语言 。 在 浏览 器 中 显示 的 效 
果 如 图 3-30 所 示 。 


而 


九 九 乘法 口诀 表 
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图 3-30 九 九 乘法 口诀 表 PHP 程序 的 运行 效果 
3.6 本 章 小 结 
本 章 主要 介绍 了 PHP 的 基本 语法 , 包括 PHP 常量 与 变量 、 运 算 符 和 表达 式 ， 以 及 PHP 


程序 中 常用 的 流程 控制 语 铅 ， 这 些 都 是 PHP 网 络 编程 必 备 的 基础 知识 ， 读 者 务必 要 全 面 理 
解 与 掌握 。 
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简 述 PHP 可 支持 哪些 数据 类 型 ， 有 哪些 运算 符 。 

简 述 PHP 程序 有 哪儿 种 流程 结构 。 

举例 说 明 在 PHP 中 实现 分 支 结构 程序 和 循环 结构 程序 的 所 有 语句 。 
简 述 如 何 利 用 PHP 语言 定义 类 和 对 象 。 


一 


3.8 上 机 实战 


1. 在 HIML 语言 中 典 入 PHP 程序 , 要 求 在 显示 器 上 分 行 显示 “World Peace Long Live! ” 
和 “世界 和 平 万 岁 ! ”， 其 中 字体 为 粗 体 ， 颜 色 为 红色 ， 居 中 显 
2. 试 编写 一 个 PHP 程序 , 并 命名 为 ciclearea php， ert 算 和 显示 | -个 圆 的 面积 
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六 
品 
名 


PHP 函数 的 定义 与 调用 
PHP 内 置 函 数 
PHP 内 置 数组 
函数 的 参数 传递 
字符 串 处 理 函 数 
数组 、 时 间 日 期 函数 
数学 、 图 像 处 理 函 数 
自 定 义 函 数 
本 章 导读 : 

将 一 系列 语句 组 合 在 一 起 ， 并 给 它们 取 一 个 统一 的 名 字 ， 这 就 是 函数 。PHP 语言 的 一 
大 特色 就 是 为 程序 员 提 供 了 大 量 功 能 强大 、 内 容 丰 富 的 函数 。 在 程序 的 编写 过 程 中 往往 会 
有 一 些 反复 用 到 的 功能 模块 ， 如 果 每 次 都 要 重复 编写 这 些 代码 ， 不 仅 浪费 时 间 ， 而 且 还 会 
使 程序 变 得 宛 长 、 可 读 性 差 ， 维 护 起 来 很 不 方便 。PHP 允许 程序 员 用 户 自行 将 某 些 程序 代 
码 组 合 在 一 起 ， 将 常用 的 流程 或 者 变量 组 织 成 一 个 函数 ， 并 且 在 程序 的 其 他 地 方 可 多 次 调 
用 。PHP 除了 大 量 的 系统 函数 外 ， 还 有 很 多 内 置 数组 ， 这 些 数 组 可 以 完成 特别 的 用 途 。 本 
章 主要 介绍 的 是 如 何 自 定义 函数 、 常 用 的 内 置 函 数 及 内 置 数组 的 功能 和 用 法 ， 以 及 在 程序 
中 如 何 调用 函数 。 
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4.1 PHP 内 置 函数 概述 


PHP 提供 了 丰富 的 函数 和 语言 结构 ， 其 中 函数 分 为 内 置 函 数 与 用 户 自 定义 函数 。 大 部 
分 内 置 函数 可 以 在 程序 代码 中 直接 调用 ， 而 某 些 内 置 函数 需要 特定 的 PHP 扩展 模块 支持 ， 
否则 将 会 在 编译 中 出 现 错误 。 自 定义 函数 则 是 根据 用 户 自己 的 需求 编写 的 函数 。 


4.1.1 PHP 标准 函数 与 扩展 函数 


PHP 开发 者 在 开发 PHP 时 编写 了 很 多 内 置 函 数 ， 这 些 函 数 功 能 强大 ， 内 容 丰 富 ， 可 以 
大 大 节省 应 用 程序 的 开发 时 间 。 按 照 内 置 函数 的 引用 方式 不 同 ， 可 将 其 分 为 标准 函数 和 扩 
展 函 数 。 

标准 函数 集成 在 PHP 解析 器 中 ， 所 以 不 用 定义 就 可 以 直接 使 用 。 使 用 过 程 中 要 注意 函 
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数 的 参数 类 型 、 调 用 方法 、 返 回 值 以 及 格式 , 如 常用 的 数学 函数 floor0、abs0、min0、maxO 
等 都 属于 这 类 函数 。 和 用 户 自 定义 函数 相 比 ，PHP 标准 函数 使 用 更 简单 方便 ， 用 户 不 需 事 
先 定义 ， 也 不 必 担 心 函数 本 身 有 什么 语法 和 功能 错误 ， 因 为 它们 已 经 被 实践 反复 证 明 是 正 
确 无 误 的 。 

在 PHP 内 置 函数 中 ， 还 有 一 些 需 要 和 特定 的 PHP 扩展 模块 一 起 编译 ， 和 否则 系统 会 提 
示 “ 未 定义 函数 ”错误 。 例 如 ， 要 使 用 图 像 处理 函 数 imageellipse0 来 画 一 个 椭圆 ， 就 需要 
在 编译 PHP 时 加 上 对 GD 库 的 支持 。 在 PHP 5 中 ， 扩 展 函 数 被 存放 在 PHP 安装 目录 的 ext 
子 目 录 下 ， 如 图 4-1 所 示 ， 这 些 函数 大 都 是 以 DLL 文件 形式 存放 的 。 


文件 四 “ 躺 竹 国 ， 坦 看 轨 ， 中 这 内。 工具 加 动 0 E32 
日 珊 - 日 请 /DRI XDD DG 
Ty 习 目 于 


峰 半 ” 国 S” 则 ” 则 六” 
EE | 

轿 汉 "” 轿 当 5. 国政” 国 壹 ” 

om tt 
ES en eo Es 

Ee Bom om on 

ep 
EV EB Ec Ee 村 2 王国 阁 吉 ae 
图 4-1 PHP 内 置 扩展 函数 库 


4.1.2 启用 扩展 函数 库 


初次 安装 PHP 时 ， 大 多 数 库 函数 都 是 被 屏蔽 了 的 。 要 想 启用 一 个 扩展 函数 非常 容易 ， 
只 需要 在 php.ini 文件 中 找到 相关 的 行 ， 将 行 首 的 分 号 “;” 去 掉 后 重新 保存 php.ini 文件 即 
可 。 例如， 用 户 要 启用 图 像 处 理 函 数 ， 则 须 在 php.ini 文件 中 找到 “;extension=php_gd2.dll” 
这 一 行 ， 然 后 将 行 首 的 “;” 去 掉 ， 重 新 启动 Apache 服务 器 使 之 生效 ， 这 样 PHP 解析 器 在 
启动 时 就 会 加 载 GD 库 函 数 ， 然 后 就 可 以 像 使 用 内 置 的 标准 函数 那样 使 用 有 关 图 像 处 理 的 
函数 。 


4.2 PHP 内 置 数组 


在 第 3 章 中 讲 到 了 一 种 特殊 数据 类 型 即 数组 , 实际 上 除了 用 户 自 定义 的 数组 之 外 , PHP 
还 提供 了 一 套 附 加 的 内 置 数 组 ， 也 叫 预 定义 数组 ， 它 们 是 一 类 特殊 的 数组 ， 在 全 局 范围 内 
自动 生效 ， 在 程序 中 直接 使 用 ， 而 无 须 事先 定义 和 初始 化 。 这 些 数组 变量 包含 了 来 自 Web 
服务 器 、 运 行 环境 和 用 户 输入 的 数据 。 


也 
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4.2.1 PHP 5 内 置 数组 简介 

表 4-1 列 出 了 一 些 常用 的 内 置 数组 ， 这 些 数组 包含 了 来 自 Web 服务 器 、 运 行 环境 以 及 
用 户 输入 的 数据 。 由 于 它们 在 程序 的 全 局 范围 内 都 有 效 ， 因 此 通常 被 称 为 自动 全 局 变量 或 
者 超 全 局 变量 。 

表 4-1 PHP 中 内 置 数 组 
预定 义 变量 描述 应 用 示例 
SGLOBALS | 包含 一 个 引用 指向 每 个 当前 脚本 的 全 局 范围 内 有 | 用 $GLOBALS["a"] 可 访问 在 脚本 中 
效 的 变量 ， 该 数组 的 键 名 为 全 局 变量 的 名 称 定义 的 全 局 变量 $a 


$_SERVER 


$_GET 


$_POST 


$_COOKIE 


$_REQUEST 


$_FILES 


由 Web 服务 器 设 定 或 者 直接 与 当前 脚本 的 执行 环 
境 相关 联 ， 是 一 个 包含 诸如 头 信息 、 路 径 和 脚本 
位 置 的 数组 ， 该 数组 的 实体 由 Web 服务 器 创建 。 

在 脚本 中 可 以 用 phpinfo0 函 数 来 查看 其 内 容 

经 由 URL 请 求 提 交 至 脚本 的 变量 ， 是 通过 HTTP 
GET 方法 传递 的 变量 组 成 的 数组 ， 可 用 来 获取 附 
加 在 URL 后 面 的 参数 值 

经 由 HTTP POST 方法 提交 至 脚本 的 变量 , 是 通过 
HTTP POST 方法 传递 的 变量 组 成 的 数组 ， 可 用 来 
获取 用 户 通 过 表单 提交 的 数据 

经 由 HTTP Cookies 方法 提交 至 脚本 的 变量 ,是 通 
过 HTTP Cookies 传递 的 变量 组 成 的 数组 ,可 用 于 
读 取 Cookie 值 

经 由 GET、POST 和 COOKIE 机 制 提交 至 脚本 的 
变量 ， 因 此 该 数组 并 不 值得 信任 。 所 有 包含 在 该 
数组 中 的 变量 的 存在 与 否 以 及 变量 的 顺序 均 按 照 
php.ini 中 的 variables_order 配置 指示 来 定义 

经 由 HTTP POST 文件 上 传 而 提交 至 脚本 的 变量 ， 
是 通过 HTTP POST 方法 传递 的 已 上 传 文件 项 目 
组 成 的 数组 ， 可 用 于 PHP 文件 上 传 编程 


用 $_ SERVER["PHP SELF"] 可 获取 
当前 正在 执行 脚本 的 文件 名 ， 与 


document root 相关 


用 $_GET["id"] 可 获取 附加 在 URL 
后 的 名 为 id 的 参数 的 值 


用 $_ POST["name"] 可 获取 通过 表单 
提交 的 名 为 name 的 表单 元 素 的 值 


用 $_COOKIE["email"] 可 获取 存储 
在 客户 端的 名 为 email 的 Cookie 值 


$_REQUEST 数组 包括 GET、POST 
和 COOKIE 的 所 有 数据 


用 $_FILES["userfile"]["name"] 可 获 
取 客 户 端 机 器 文件 的 文件 名 


$_SESSION 


是 当前 注册 给 脚本 会 话 的 变量 ， 是 包含 当前 脚本 
中 会 话 变量 的 数组 ， 可 用 于 访问 会 话 变量 


4.2.2 ”接收 表单 数据 和 URL 附加 数据 


用 $_SESSION["user level"] 可 检索 
名 为 user level 的 会 话 变量 的 值 


在 第 2 章 有 关 表 单 标记 的 基础 知识 中 已 经 讲述 过 ， 网 页 之 间 的 数据 传递 方式 有 两 种 : 
一 种 是 用 POST 方法 来 接收 表单 数据 ， 另 一 种 是 用 GET 方法 来 获取 URL 中 附加 的 数据 。 
这 两 种 方法 分 别 要 用 到 $_POST 内 置 数 组 和 $_GET 内 置 数组 ， 其 作用 是 将 客户 端 表 单 内 的 数 
据 传送 到 服务 器 中 。 


例如 ， 下 面 


器 中 进行 汇总 并 将 结果 返回 至 客户 端的 功能 。 


的 例子 ， 实 现 了 将 客户 端 表单 中 提交 的 两 个 数 传送 到 服务 器 端 ， 然 后 在 服务 
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<HTML> 

<HEAD> 

<TITLE> 网 页 中 的 数据 传递 </TITLE> 

</HEAD> 

<BODY> 

<?php 

$CFQ=$_POST["tag"]; // 用 来 判断 用 户 是 否 单 击 了 计算 按钮 

if ($CFQ ==1){ // 用 户 单 击 计 算 按 钮 , 则 分 别 将 两 个 文本 框 的 数据 存放 到 两 个 变量 中 
$addnum1=$_POST["addnum1"]; // 通 过 $_POST 内 置 数组 获取 第 一 个 加 数 
$addnum2=$_POST["addnum2"]; 。 // 通 过 $_POST 内 置 数组 获取 第 二 个 加 数 
} 

else /用 户 没 单 击 “ 计 算 ” 按 钮 ， 则 将 两 个 变量 赋值 为 0 
{ 
$addnum1=0; 
$addnum2=0; 


1 
S$sum=$addnum1+$addnum2; // 对 两 个 变量 中 存放 的 加 数 求 和 
?> 
在 表单 输入 两 个 加 数 
<form name="form1" method="post" action="#"> 
<input type="hidden" name="tag" size="4" value="1"> 
<input type="text" name="addnum1" size="4" value="<?php echo $addnum1;?>"> 
是 
<input type="text" name="addnum2" size="4" value="<?php echo $addnum2;?>"> 
<?php echo $sum;?><br> // 输 出 计算 结果 
<br><input type="submit" name="Submit" value=" 计 算 "> 
<input type="reset" name="Submit2" value=" 重 置 "> 
</form> 
</BODY> 
</HTML> 


以 上 代码 运行 后 的 效果 如 图 4-2 所 示 。 


三 同 页 中 的 数据 传递 - Yindows Internet ERIC -lolx| 
GO | ea x pl 
| 文件 加” 编 句 中 查看 WD 收藏 天 W) 工具 GD) 帮助 0) 

地 收 案 天 。 局 Ti 中 的 数据 传闻 | | 


在 表单 输入 两 个 加 数 习 
1s 
| 本 | 

到 


同 teret ET 


图 4-2 用 POST 传递 数据 
下 面 介绍 如 何 运 用 GET 方法 传递 数据 。 


<HTML> 
<HEAD> 
<TITLE>URL 附加 数据 传递 </TITLE> 
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</HEAD> 
<BODY> 
<a href="chap4_nzsz2.php?show_tag=1"> 显 示 文 字 </a> 
<a href="?show_tag=2"> 隐 藏 文字 </a><br><br> 
<?php 
$show_tag=$_GETI["show. tag"]; // 用 内 置 数组 $_GET 来 获取 URL 附加 数 
if ($show_tag==1){ 
echo "如 果 您 看 到 了 这 段 文字 , 则 说 明 通过 show_tag 传递 了 1, 这 可 以 从 网 页 地 址 栏 上 的 URL 
地 址 可 以 查看 到 。 否 则 传递 了 2"; 
1 
?> 
</BODY> 
</HTML> 


该 程序 的 运行 结果 如 图 4-3 所 示 。 


文 和 四” 忽 强 攻 ]】 查看 如 收 基 天 内 工具 四 各 动 
这 中 局 天 。 逢 n 六 加 数据 进 


显示 文字 隐 基 文字 


汪 和 和 ho tse 传递 了 1， 这 可 以 从 网 页 地 址 栏 上 的 UR 地 
址 可 以 查看 到 。 否 则 传递 


图 4-3 用 GET 传递 数据 
4.2.3 用 Session 和 Cookie 实现 用 户 登录 


Session 和 Cookie 在 Web 技术 中 有 着 非常 重要 的 作用 。 例 如 ， 在 某 些 网 站 中 常常 要 求 
用 户 先 登录 ， 但 系统 怎么 判断 用 户 是 否 已 经 登录 了 呢 ? 解决 这 个 问题 最 简单 的 办 法 就 是 利 
用 Session 和 Cookie 机 制 。 如 果 没 有 Session 和 Cookie， 则 用 户 登 录 信 息 是 无 法 保留 的 。 

Session 也 称 为 会 话 。 当 用 户 登录 或 访问 - 些 初始 页 面 时 ， 服 务 器 会 为 客户 端 临 时 分 配 

一 个 随机 数字 即 Session ID， 在 会 话 的 生命 周期 (从 网 站 最 初 建 立 连接 开始 ， 至 关闭 浏览 器 

断 开 网 站 连接 为 止 ) 中 保存 在 客户 端 。 用 户 通过 Session ID 可 以 注册 一 些 特 殊 的 变量 ， 称 
为 会 话 变量 ， 这 些 变量 的 数据 保存 在 服务 器 端 ， 从 而 使 服务 器 端 能 够 实时 地 了 解 客户 六 用 
户 的 信息 。 断 开 网 站 连接 之 后 ，Session 会 ,自动 失效 ， 之 前 注册 的 会 话 变量 也 不 能 再 使 用 。 
如 果 配 置 文件 php.ini 中 没有 设置 “session.auto_start=1”， 那 么 要 使 用 Session 就 必须 先 运 
行 代码 session_start0。 运 行 时 ， 就 在 服务 器 上 产生 了 一 个 Session 文件 ， 随 之 也 产生 了 一 个 
与 之 唯一 对 应 的 Session ID 。 

下 面 举 一 个 用 户 登录 的 例子 。 该 例子 由 两 个 程序 组 成 ， 程 序 chap4_nzsz3.php 用 于 获取 
用 户 信 息 并 将 该 信息 通过 Session 内 置 数组 保存 至 服务 器 ， 程序 chap4_nzsz3success.php 用 来 
定义 用 户 登 录 成 功 后 输出 的 信息 。 

chap4_nzsz3.php 程序 代码 如 下 : 


ge 
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<html> 
<body> 
<form action="chap4_nzsz3.php" method="post"> 
<table border="0" align="center"> 
<tr><td colspan="2" align="center"> 用 户 登录 </td></tr> 
<tr><td align="center"> 用 户 名 </td><td><input name="username" type="text"></td></tr> 
<tr><td align="center"> 密 码 </td><td><input name="password" type="password"></td></tr> 
<tr><td colspan="2" align="center > 
<input type="submit" name="Submit" value=" 登 录 "> 
<input type="reset" name="Submit2" value=" 重 置 "> </td></tr> 
</table> 
</form> 
</body> 
</html> 
<?php 
session_start(); 
if(isset($_POST['Submit)) 
ii 
Susername=$_POST[usemame']; 
$password=$_POST['password']; 
if($username=="administrator"&&$password=="123456") 
{ 
$_SESSION['username']=$username; 
$_SESSION['password']=$password; 
header("location: chap4_nzsz3sucess.php"); 
} 
else 
echo "<script>alert(' 登 录 失败 ');location.href='chap4_nzsz3.php';</script>"; 
} 
} 


?> 


需要 提醒 的 是 ， 本 程序 倒数 第 8 行 “header("location: chap4_nzsz3sucess.php");” 中 用 
到 了 页 面 跳 转 语句 header， 它 告诉 程序 此 处 应 转 到 什么 页 面 上 去 。 
chap4_nzsz3sucess.php 程序 代码 如 下 : 


<?php 
session_start(); 
$username=@$_SESSION['username'; 
S$password=@$_SESSION['password']; 
if($username) 

echo "欢迎 管理 员 登 录 ， 您 的 密码 为 S$password"; 
else 

echo "对 不 起 ， 您 没有 权限 登录 本 页 "; 


?> 


本 例 实际 的 运行 效果 如 图 4-4 和 图 4-5 所 示 。 
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图 4-4 用 户 登 录 页 面 图 4-5 用 户 登录 成 功 后 的 页 面 


与 Session 将 用 户 数据 存储 在 服务 器 端 相 反 ，Cookie 是 一 种 在 浏览 器 端 储存 数据 并 以 此 
来 跟踪 和 识别 用 户 的 机 制 ， 而 且 从 客户 端 发 送 的 cookie 都 会 被 PHP 5 自动 包括 进 $ COOKIE 
内 置 数 组 中 。 如 果 希 望 对 一 个 Cookie 变量 设置 多 个 值 ， 则 需 在 cookie 的 名 称 后 加 “[" 值 名 
称 "]” 符 号 。 设 置 Cookie 常用 到 的 函数 是 setcookie， 其 语法 格式 如 下 : 

int setcookie(string name, string value, int expire, string path, string domain, int secure); 

其 中 ,参数 name 表示 cookie 的 名 称 ; value 表示 cookie 的 值 ， 该 参数 为 空 字符 串 则 表示 
取消 浏览 器 中 该 cookie 的 资料 ; expire 表示 该 cookie 的 有 效 时 间 ; path 为 该 cookie 的 相关 路 径 ; 
domain 表示 cookie 的 网 站 ; secure 则 是 在 https 的 安全 传输 时 才 有 效 。 上 述 参数 中 , 除了 name 
之 外 ， 其 他 都 是 可 以 省 略 的 。 例 如 ， 前 面 讲 到 的 用 户 登 录 例 子 ， 也 可 以 通过 cookie 来 实现 。 

chap4_nzsz4.php 程序 代码 如 下 : 


<html> 
<body> 
<form action="chap4_nzsz4.php" method="post"> 
<table border="0" align="center"> 
<tr><td align="center"> 用 户 名 </td><td><input name="username'" type="text"></td></tr> 
<tr><td align="center"> 密 码 </td><td><input name="password" type="password"></td></tr> 
<tr><td>Cookie 保存 时 间 </td> 
<td><select name="time"> 
<option value="0" selected> 不 保存 </option> 
<option value="1"> 保 存 一 小 时 </option> 
<option value="2"> 只 保存 一 天 </option> 
<option value="3"> 保 存 一 个 星期 </option> 
</select></td></tr> 
<tr><td colspan="2" align="center > 
<input type="submit" name="Submit" value=" 登 录 "> 
<input type="reset" name="Submit2" value=" 重 置 "></td></tr> 
</table> 
</form> 
</body> 
</html> 
<?php 
setcookie("username"); 
iflisset($_POST['Submit]) 
{ 


$username=$_POST[username ]; 
$password=$_POST[password]; 
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$time=$_POST[time]; 
if($username=="administrator"&&$password=="123") 
1 
switch($time) 
tl 
case 0: 
setcookie("username", $username); 
break; 
case 1: 
setcookie("username", $username,time()+60*60); 
break; 
case 2: 
setcookie("username", $username,time()+24*60*60); 
break; 
case 3: 
setcookie("username", $username,time()+7*24*60*60); 
break; 
有 
header("location:chap4_nzsz4sucess.php"); 
} 


else 


{ 
} 


echo "<script>alert(' 登 录 失 败 ');location.href='chap4_nzsz4.php';</script>"; 


} 


Wd 


chap4_nzsz4sucess.php 程序 代码 如 下 : 


<?php 
if($username=@$_COOKIE['username']) 


echo "欢迎 用 户 ".$username." 登 录 "; 


} 
else 

echo "对 不 起 ， 你 无 权限 访问 本 页 面 "; 
Ye 


本 例 实际 的 运行 页 面 如 图 4-6 和 图 4-7 所 示 。 
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“路 半天 http://locilhost/phpbooksour ,| 


用 户 名 Finistrator | 二 
i = 欢迎 用 户 administrator 登 录 FE 


于 码 
Cooksie 保 存 时 间 


图 4-6 用 户 登录 页 面 图 4-7 用 户 登录 成 功 的 页 面 
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4.3 PHP 数组 函数 


在 编写 PHP 程序 时 ， 经 常 要 用 到 数组 。 数 组 是 一 种 复合 数据 类 型 ， 很 多 信息 都 需要 用 
数组 作为 载体 进行 保存 。 数 组 在 PHP 编程 中 占有 很 大 比重 ， 要 想 得 心 应 手 地 编写 PHP 程 
序 ， 必 须 掌 握 好 PHP 数组 函数 。 


4.3.1 数组 函数 总 览 


第 3 章 中 介绍 了 如 何在 PHP 中 定义 和 使 用 数组 , 读者 对 数组 己 有 了 一 定 了 解 。 实 际 上 ， 
PHP 中 还 提供 了 一 些 用 来 操作 数组 的 函数 ， 这 些 函数 作为 系统 的 内 置 标准 函数 可 以 直接 使 
用 。 下 面 用 列表 的 方式 来 说 明 常 用 的 数组 函数 及 功能 ， 如 表 4-2 所 示 。 

表 4-2 PHP 中 的 数组 函数 


函数 名 称 函数 功能 描述 
array_change_key_case 返回 字符 串 键 名 全 为 小 写 或 大 写 的 数组 
array_chunk 将 一 个 数组 分 割 成 多 个 
array_combine 创建 一 个 数组 ， 用 一 个 数组 的 值 作为 其 键 名 ， 另 一 个 数组 的 值 作为 其 值 
array_count_values 统计 数组 中 所 有 的 值 出 现 的 次 数 


带 索引 检查 计算 数组 的 差 集 


array_diff assoc 


array_fill 用 给 定 的 值 填 充 数组 
flip 交换 数组 中 的 键 和 值 


带 索引 检查 计算 数组 的 交集 


array_intersect_assoc 


array_intersect 


array_key exists 检查 给 定 的 键 名 或 索引 是 否 存在 于 数组 中 
array_keys 返回 数组 中 所 有 的 键 名 

array_map 将 回调 函数 作用 到 给 定数 组 的 单元 上 
armray_merge_rectsive 递归 地 合并 两 个 或 多 个 数组 

array_merge 合并 两 个 或 多 个 数组 

amray Inultisort 对 多 个 数组 或 多 维 数组 进行 排序 

amay pad 用 值 将 数组 填补 到 指定 长 度 

array pop 将 数组 最 后 一 个 单元 弹出 〈 出 栈 ) 
array_push 将 一 个 或 多 个 单元 压 入 数组 的 末尾 〈 入 栈 ) 
array Iand 从 数组 中 随机 取出 一 个 或 多 个 单元 
array_reduce 用 回调 函数 迭代 地 将 数组 简化 为 单一 的 值 
array_reverse 返回 一 个 单元 顺序 相反 的 数组 
array_search 在 数组 中 搜索 给 定 的 值 ， 如 果 成 功 则 返回 相应 的 键 名 
array_shift 将 数组 开头 的 单元 移出 数组 

array slice 从 数组 中 取出 一 段 
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续 表 
函数 名 称 函数 功能 描述 
array_splice 把 数组 中 的 一 部 分 去 掉 并 用 其 他 值 取代 
alray_sum 计算 数组 中 所 有 值 的 和 
array_unique 移 除 数组 中 重复 的 值 
array_unshift 在 数组 开头 插入 一 个 或 多 个 单元 
array values 返回 数组 中 所 有 的 值 
array_walk 对 数组 中 的 每 个 成 员 应 用 用 户 函 数 
array 新 建 一 个 数组 
arsort 对 数组 进行 逆向 排序 并 保持 索引 关系 
asort 对 数组 进行 排序 并 保持 索引 关系 
compact 建立 一 个 数组 ， 包 括 变量 名 和 它们 的 值 
count 统计 数组 中 的 单元 数目 或 对 象 中 的 属性 个 数 
current 返回 数组 中 的 当前 单元 
each 返回 数组 中 当前 的 键 〈( 下 标 ) 值 对 ， 并 将 数组 指针 向 前 移动 一 步 
end 将 数组 的 内 部 指针 指向 最 后 一 个 单元 
extract 从 数组 中 将 变量 导入 到 当前 的 符号 表 
in aray 检查 数组 中 是 否 存在 某 个 值 
key 从 结合 数组 中 取得 键 名 
krsort 对 数组 按照 键 名 逆向 排序 
ksort 对 数组 按照 键 名 排序 
list 把 数组 中 的 值 赋 给 一 些 变 量 
natcasesort 用 “自然 排序 ”算法 对 数组 进行 不 区 分 大 小 写字 母 的 排序 
natsort 用 “自然 排序 ”算法 对 数组 排序 
next 将 数组 中 的 内 部 指针 向 前 移动 一 位 
pos 得 到 数组 当前 的 单元 
TeV 将 数组 的 内 部 指针 倒 回 一 位 
range 建立 一 个 包含 指定 范围 单元 的 数组 
reset 将 数组 的 内 部 指针 指向 第 一 个 单元 
rsort 对 数组 逆向 排序 
shuffle 将 数组 打 乱 
sizeof countO 的 别名 ， 用 于 统计 数组 中 的 单元 数目 或 对 象 中 的 属性 个 数 
sort 对 数组 排序 
uasort 使 用 用 户 自 定义 的 比较 函数 对 数组 中 的 值 进 行 排序 并 保持 索引 关联 
uksort 使 用 用 户 自 定义 的 比较 函数 对 数组 中 的 键 名 进行 排序 
Usort 使 用 用 户 自 定义 的 比较 函数 对 数组 中 的 值 进行 排序 


PHP 中 的 数组 函数 非常 多 ， 这 里 只 罗列 了 其 中 部 分 常用 的 。 读 者 不 必 被 这 么 多 的 函数 


吓 倒 ， 在 开始 学 习 时 只 需 仔细 浏览 一 下 这 些 函数 ， 而 不 必 去 强行 记忆 。 在 实际 编程 过 程 中 ， 
下 根据 程序 需要 去 查找 函数 手册 学 习 相关 函数 及 其 使 用 方法 即 可 。 下 面 讲述 表 中 几 个 最 党 
的 数组 函数 的 使 用 方法 ， 其 他 函数 的 使 用 方法 读者 可 自行 查看 PHP 参考 手册 。 
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4.3.2 array() 函 数 


arrayO 函 数 用 来 创建 一 个 新 数组 。 创 建 数组 通常 有 两 种 方法 : 一 种 是 给 数组 每 个 变量 


赋值 《这 种 方式 已 在 第 3 章 中 讲述 过 ) ; 另 一 种 就 是 同时 给 数组 所 有 元 素 赋值 ， 此 时 就 要 


用 到 array0 函 数 。 例 如 : 


<?php 

$arrNo1=array(4,5,6,7,8,9); 
$arrNo2=array("a"=>4,"b"=>5,"c"=>6,"d"=>7,"e"=>8,"f"=>9); 
echo "\$arrNo1[0]=".$arrNo1[0]; 

echo "<br>"; 

echo "$arrNo2[\"a\"]=".$arrNo2["a"]; 

?> 


在 本 例 中 ， 分 别 用 两 种 方法 定义 了 两 个 数组 。 第 一 种 省 略 了 数组 下 标 及 键 名 ， 此 时 系 


统 采用 默认 的 下 标 为 每 个 元 素 分 配 下 标 ， 即 从 0 开始 分 配 ， 故 $arrNol[0] 元 素 的 值 就 是 数组 
arrNol 的 第 一 个 元 素 即 4， 而 $arNol[1] 代 表 的 是 arrNol 数组 的 第 二 个 元 素 。 第 二 种 方法 


是 通过 用 户 自 定义 元 素 的 下 标 来 完成 数组 的 创建 ， 数 组 元 素 下 标 可 以 是 整 型 数 或 字符 串 ， 


所 以 ，$arrNo2["a"] 代 表 的 是 数组 下 标 为 “a” 的 元 素 ， 在 本 例 中 该 元 素 的 值 为 4。 


在 浏览 器 中 查看 以 上 代码 输出 结果 如 图 4-8 所 示 。 


/C Array 函 数 的 使 用 - Windows Internet EARL 


GO | /amvnr +) x lei 


」 文件 D 出错 ) 查看 WD 收 区 天 W， 工具 一 0 


这 收藏 严 。。 胞 Arrwy 函 数 的 使 用 


$arrNol [0]=4 
$arrNo2[”a”]=4 


图 4-8 array0 函 数 的 使 用 


4.3.3 count() 函 数 


count() 函 数 用 来 统计 一 个 数组 中 元 素 的 个 数 。 在 循环 输出 某 数 组 的 所 有 元 素 时 ， 必 须 


先知 道 该 数组 中 一 共 包含 多 少 个 元 素 ， 此 时 就 要 用 到 count0 函 数 。 其 用 法 如 下 : 


<?php 
$arr1=array(1,2,3,4,.5，6); 
echo "数组 \$arr1 中 元 素 的 个 数 是 : "count($arr1); 


?> 


在 本 例 中 ， 首 先 定义 了 一 个 $arrl 数组 ,然后 将 该 数组 作为 count0 函 数 的 参数 ， 从 而 统 


计 出 这 个 数组 的 元 素 个 数 。 以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 4-9 所 示 。 
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数组 garrl 中 元 素 的 个 数 是 : 6 


Fa | te 


图 4-9 ”count0 函 数 的 使 用 


4.3.4 each() 函 数 


each0) 函 数 返 回 数组 中 当前 元 素 的 索引 即 键 (key)〉 和 内 容 (value) ， 并 将 数组 指针 向 
前 移动 到 下 一 个 元 素 。 该 函数 通常 被 用 在 一 个 循环 中 遍历 一 个 数组 。 例 如 : 


<?php 
$arr = array("name"=>" 张 三 ","age"=>31,"sex"=>" 男 ","personID"=>"32424212100000"); 
for($i=0;$i<count($arr);$i++)f 

$keyvaule=each($arr); 

echo $ keyvaule ["key"]."=>".$ keyvaule ["value ]; 

echo "<br>"; 


} 


?> 

在 本 例 中 ， 首 先 定义 了 一 个 包含 4 个 元 素 的 数组 ,然后 在 for 循环 中 利用 each0) 函 数 对 
每 个 元 素 进行 遍历 。 需要 注意 的 是 ，each0 函 数 返回 的 结果 实际 上 又 是 一 个 数组 ， 即 数组 元 
素 的 下 标 (key) 和 内 容 (value)， 它 们 被 一 起 存储 到 $keyvaule 中 ,然后 通过 显示 $keyvaule 
中 的 元 素 值 来 查看 数组 $arr 中 元 素 的 下 标 和 内 容 。 程 序 运 行 后 的 页 面 如 图 4-10 所 示 。 


x=> 男 
personID=>32424212100000 


图 4-10 eachO 函 数 的 使 用 
4.3.5 ”current()、reset()、end()、next() 和 prev() 函 数 


数组 中 往往 有 多 个 元 素 ， 如 何 知道 数组 当前 的 元 素 是 哪 一 个 ， 又 如 何 访问 其 他 位 置 的 
元 素 呢 ? 这 些 操作 涉及 到 数组 指针 的 问题 。 每 个 数组 都 有 一 个 指针 ， 它 指向 当前 的 元 素 。 
在 进行 PHP 编程 中 ， 有 时 需要 对 数组 指针 进行 移动 操作 ， 这 些 操作 往往 涉及 current()、 
Ieset0、end0、next0 和 prev0 等 函数 。 例 如 : 


<?php 
$arr=array( 第 一 个 "第 二 个 "第 三 个 "第 四 个 "第 五 个 ,第 六 个 "第 七 个 "第 八 个 '); 
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echo "调用 current() 函 数 后 :".current($arr); 
echo "<br>"; 

echo "再 次 调用 current() 函 数 后 指针 指向 :".current($arr); 
echo "<br>"; 

echo "调用 next() 函 数 后 指针 指向 :".next($arr); 
echo "<br>"; 

echo "调用 reset() 函 数 后 指针 指向 :".reset($arr); 
echo "<br>"; 

echo "调用 end() 函 数 后 指针 指向 :".end($arr); 
echo "<br>"; 

echo "调用 prev() 函 数 后 指针 指向 :".prev($arr); 


?> 


以 上 代码 在 浏览 器 中 的 实际 输出 结果 如 图 4-11 所 示 。 


[EC 后 


上 | 文件 四 ” 油 油 如 可 者 中 收藏 天 Q) 工具 IT) 帮助 四 


二 电 妾 天。 种 并 粗毛 计 移动 本 归 的 党 应 太守 全 


调用 current () 函 数 后 :第 一 个 


图 4-11 数组 指针 函数 的 应 用 


4.4 ”字符 串 处 理 函 数 


字符 串 是 由 多 个 字符 组 成 的 序列 ， 在 PHP 编程 过 程 中 ， 帮 


` 管 是 进行 文本 的 处 理 还 是 字 


符 的 操作 都 离 不 开 字 符 串 。 在 信息 管理 系统 中 ， 大 量 信息 也 是 由 字符 串 来 储存 的 。PHP 为 
程序 员 提 供 了 大 量 实用 的 字符 串 处 理 函 数 ， 利 用 这 些 函 数 可 以 完成 许多 复杂 的 字符 串 处 理 
工作 。 


4.4. 


1 字符 串 处 理 函 数 总 览 


PHP 中 用 于 处 理 字符 串 的 函数 非常 多 ， 为 了 方便 读者 学 


习 和 查阅 ， 下 面 通过 列表 的 形 


式 对 常用 的 字符 串 处 理 函 数 做 一 个 说 明 ， 如 表 4-3 所 示 。 
表 4-3 PHP 中 的 字符 串 处 理 函 数 
函 数 名 函数 功能 描述 
addcslashes 为 字符 串 中 的 部 分 字符 添加 反 斜 线 转 义 字符 
addslashes 用 指定 的 方式 对 字符 串 中 的 字符 进行 转 义 
bin2hex 将 二 进 制 数据 转换 成 十 六 进 制 表示 


chr 


返回 一 个 字符 的 ASCI 码 
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续 表 
函 数 名 函数 功能 描述 
chunk split 按 一 定 的 字符 长 度 将 字符 串 分 割 成 小 块 
convert cyT string 将 斯 拉夫 语 字 符 转 换 为 别 的 字符 
convert uudecode 解密 一 个 字符 串 
convert uuencode 加 密 一 个 字符 串 
count chars 返回 一 个 字符 串 中 的 字符 使 用 信息 
crc32 计算 一 个 字符 串 的 crc32 多 项 式 
explode 将 一 个 字符 串 用 分 割 符 转 变 为 一 数组 形式 
printf 按照 要 求 对 数据 进行 返回 ， 并 直接 写 入 文档 流 
htmlspecialchars 将 字符 串 中 的 一 些 字符 转换 为 HTML 实体 
implode 将 数组 用 特定 的 分 割 符 转变 为 字符 串 
join 将 数组 转变 为 字符 串 ，implode0 函 数 的 别名 
ltrim 去 除 字 符 串 左 侧 的 空白 或 者 指定 的 字符 
md5 file 将 一 个 文件 进行 MD5 算法 加 密 
md5 将 一 个 字符 串 进行 MD5 算法 加 密 
nl2br 将 字符 串 中 的 换行 符 “\n” 替 换 成 回 车 换行 符 “<br>” 
number format 按照 参数 对 数字 进行 格式 化 的 输出 
ord 将 一 个 ASCII 码 转换 为 一 个 字符 
print 用 以 输出 一 个 单独 的 值 
printf 按照 要 求 对 数据 进行 显示 
quoted printable decode 将 一 个 字符 串 加 密 为 一 个 8 位 的 二 进 制 字符 串 
rtrim 去 除 字符 串 右 侧 的 空白 或 者 指定 的 字符 
sprintf 按照 要 求 对 数据 进行 返回 ， 但 是 不 输出 
str pad 对 字符 串 进 行 两 侧 的 补 白 
str_repeat 对 字符 串 进行 重复 组 合 
str_replace 匹配 和 替换 字符 串 
str_shuffle 对 一 个 字符 串 中 的 字符 进行 随机 排序 
str_split 将 一 个 字符 串 按 照 字符 间距 分 割 为 一 个 数组 
str_ word_count 获取 字符 串 中 的 英文 单词 信息 
strchr 通过 比较 返回 一 个 字符 串 的 部 分 strstrO 函 数 的 别名 
strcmp 对 字符 串 进行 大 小 比较 
strlen 获取 一 个 字符 串 的 编码 长 度 
strpbrk 通过 比较 返回 一 个 字符 串 的 部 分 
strpos 查找 并 返回 首 个 匹配 项 的 位 置 
strrev 将 字符 串 中 的 所 有 字母 反 向 排列 
strrpos 从 后 往 前 查找 并 返回 首 个 匹配 项 的 位 置 
strspn 匹配 并 返回 字符 连续 出 现 长 度 的 值 
strstr 通过 比较 返回 一 个 字符 串 的 部 分 


strtok 用 指定 的 若干 个 字符 来 分 割 字符 串 
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续 表 
函 数 名 函数 功能 描述 
strtolower 将 字符 串 转变 为 小 写 
strtoupper 将 字符 串 转 变 为 大 写 


对 字符 串 比较 替换 
计算 字符 串 中 某 字符 段 的 出 现 次 数 
对 字符 串 中 的 部 分 字符 进行 蔡 换 


strtr 


substr count 


substr replace 


substr 对 字符 串 进行 截取 

trim 去 除 字 符 串 两 边 的 空白 或 者 指定 的 字符 

ucfirst 将 所 给 字符 串 的 第 一 个 字母 转换 为 大 写 

Ucwords 将 所 给 字符 串 的 每 一 个 英文 单词 的 第 一 个 字母 变 成 大 写 


F 面 着 重 讲述 一 些 使 用 频率 较 高 的 字符 串 处 理 函数 。 
4.4.2 去除 空格 函数 


由 于 数据 存储 的 需要 ， 在 某 些 情况 下 是 不 允许 在 字符 串 中 出 现 空格 的 。 例 如 ， 当 用 户 
登录 某 个 系统 时 , 用 户 名 和 密码 的 开头 、 结尾 一 般 都 不 能 有 空格 , 所 以 在 进行 Web 编程 时 ， 
程序 员 应 该 在 程序 中 预先 去 除 这 些 空格 ， 以 保证 传送 到 服务 器 的 数据 符合 规范 。 

在 PHP 中 去 除 空格 的 内 部 函数 有 以 下 儿 种 。 

(1) trim() 函 数 

该 函数 用 于 去 除 字 符 串 开始 位 置 和 结束 位 置 的 空格 字符 ， 其 语法 格式 如 下 : 

trim(string str [, string charlist] ) 

其 中 ， 参 数 str 表示 待 处 理 的 字符 串 ，charlist 为 可 选 参数 ， 指 定 要 去 除 的 字符 ， 如 果 
不 指定 该 参数 ， 则 该 函数 将 去 除 空格 、 制 表 符 、 空 字 节 、 换 行 符 和 回 车 符 。 

(2) ltrim0 函 数 

该 函数 用 于 去 除 字符 串 左 边 的 空格 或 其 他 指定 的 字符 ， 并 返回 处 理 后 的 字符 串 ， 其 语 
法 格式 如 下 : 

ltrim(string str [, string charlist] ) 

其 中 参数 的 含义 及 功能 和 trim0) 函 数 完全 一 致 。 

(3) rtrim0) 函 数 

该 函数 用 来 去 除 字符 串 右边 的 空格 或 其 他 指定 的 字符 ， 并 返回 处 理 后 的 字符 串 ， 其 语 
法 格式 如 下 : 

rtrim(string str [,string charlist]) 

其 中 参数 的 含义 及 功能 和 trim0 函 数 完全 一 致 。 

下 面 举 例 来 说 明 这 3 个 函数 的 用 途 ， 其 PHP 代码 如 下 : 


<?php 
$str=" 初 始 字 符 左右 两 边 及 中 间 都 有 空格 "; 
echo "原始 字符 串 : ".$str."<br>"; 
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echo "原始 字符 串 长 度 : "strlen($stnD)."<br>"; 

Sstr1=ltrim($str); 

echo "用 函数 ltrim() 去 掉 左 边 的 空格 后 的 字符 串 :".$str1."<br>"; 
echo "执行 ltrim() 之 后 的 长 度 : ".strlen($str1)."<br>"; 
Sstr2=rtrim(S$str); 

echo "用 函数 rtrim() 去 掉 右 边 的 空格 后 的 字符 串 : ".$str2."<br>"; 
echo "执行 rtrim() 之 后 的 长 度 :".strlen($str2)."<br>"; 
$str3=trim($str); 

echo "执行 trim() 之 后 的 长 度 ".strlen($str3)."<br>"; 

echo "去 掉 首尾 空格 之 后 的 字符 串 : ".$str3.""; 


?> 


程序 的 运行 


-结果 如 图 4-12 所 示 。 


原始 字符 串 ， 条 始 字 符 左右 两 边 及 中 间 都 有 空格 
原始 字符 串 长 度 ; 
rin ER eT 初始 字符 左右 两 边 及 中 间 都 有 空格 
执行 ltrim() 之 后 的 长 度 ， 


Pair DER nT 初始 字符 左右 两 边 及 中 间 都 有 空格 
执行 rtrim() 之 后 的 长 度 ， 
执行 trim() 之 后 的 长 度 31 

去 捍 基 同 共和 这 月 的 字符 下 ， 初始 字符 左右 两 边 及 中 间 都 有 空格 


ml ml ml el mE 


图 4-12 变量 值 的 指定 


其 中 需要 说 明 的 是 ， 在 上 述 程序 中 用 到 了 strlen0 函 数 ， 该 函数 用 来 统计 字符 串 长 度 。 
4.4.3 HTML 处 理 相关 函数 


还 有 一 种 是 用 于 格式 化 HTML 文本 的 内 部 函数 , 通过 这 些 函 数 可 以 把 字符 串 中 的 换行 
符 转换 为 HTML 换行 标记 ， 还 可 以 实现 在 特殊 字符 与 HTML 实体 之 间 相 互 转换 或 去 除 所 
有 的 HIML 和 PHP 标记 等 。 下 面 就 来 讲述 这 些 函 数 。 
(1) nl2br0 函 数 


当 HIM 


L 文件 中 存在 “m” 时 ， 程 序 运行 后 不 能 显示 换行 效果 ， 这 时 可 以 使 用 ml2br0 


函数 将 字符 串 中 的 换行 符 “nm” 替换 为 HTML 中 的 “<br >” 标记 。 例 如 : 
<?php 
$str="Welcome to \nChengdu"; 
echo $str; // 直 接 输 出 不 会 有 换行 符 
echo nl2br($str); /1/“Welcome to” 后 面 换行 
?> 


(2) htmlspecialcharsO) 函 数 
该 函数 可 以 将 字符 转换 为 HIML 的 实体 形式 , 该 函数 转换 的 特殊 字符 及 转换 后 的 字符 
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如 表 4-4 所 示 。htmlspecialchars(O) 函 数 将 特殊 的 HTML 标签 转换 为 HTML 实体 并 以 普通 文 


本 显示 出 来 ， 可 以 用 来 防止 恶意 脚本 对 网 站 的 攻击 。 
表 4-4 可 以 转换 为 HTML 实体 形式 的 特殊 字符 


转换 后 的 字符 
Kamp; 
&quot; 
&#039; 


(3) htmlentities0 函 数 
该 函数 把 字符 串 中 的 一 些 HTML 标签 转换 为 HTML 实体 并 返回 经 过 处 理 的 字符 串 。 
与 htmlspecialchars() 函 数 类 似 ，htmlentities0 函 数 也 可 以 将 特殊 字符 转换 为 实体 。 它 们 的 区 
别 是 ;htmlspecialchars0 〇 函数 只 能 转换 有 &、"、'、< 和 > 这 5 个 字符 ， 而 htmlentities0) 函 数 可 以 
把 汉字 也 一 起 进行 转换 。 例 如 : 


<?php 

$str1="<font size=5> 这 是 中 文字 符 串 </font>"; 

echo htmlentities($str1); // 将 网 页 中 输出 <font size=5>OaECOBiAxO-0"®@</font> 
J 


(4) strip_tags0 〇 函数 
该 函数 可 以 将 字符 串 中 的 所 有 PHP 和 HTML 标记 去 除 ， 并 返回 经 过 处 理 的 字符 串 ， 
其 语法 格式 如 下 : 
strip_tags (string str [, string allowable tags]) 
参数 str 是 要 处 理 的 字符 串 ,allowable_tags 表示 指定 要 保留 的 某 些 PHP 或 HTML 标记 。 
下 面 举例 来 综合 讲解 以 上 的 HTML 处 理 的 相关 函数 ， 程 序 代码 如 下 : 


<?php 

define("SP","<br/>\n"); 

$str1=" 这 是 第 一 行文 本 。\n 这 是 第 二 行文 本 "; 

print "<b> 把 换行 符 蔡 换 成 换行 标记 </b>".nl2br($str1).SP; 

$str2="<p align=\"center\"> 文 本 内 容 </p>"; 

print "<b>HTML 段落 标记 :</b>".htmlspecialchars($str2).SP; 

$str3="<font color=\"red\"> 文 本 内 容 </font>"; 

print "<b>HTML 字体 标记 :</b>".htmlentities($str3,ENT_COMPAT,"GB2312").SP; 
$str4="<div> 一 行文 本 ，</div><!-- 这 里 是 注释 --> 这 里 是 其 他 文本 "; 

print "<b> 过 滤 掉 了 所 有 HTML 标记 :</b>".strip_tags($str4).SP; 

print "<b> 除 div 标记 外 ， 过 滤 掉 了 所 有 HTML 标记 :</b>".strip_tags($str4,"<div>").SP; 
?> 


该 程序 运行 后 的 结果 如 图 4-13 所 示 ， 请 注意 分 析 结 果 。 
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区 7 轧 叶 中 查看 WD 收 若 天 A) 工具 I) 帮助 00 
这 家 案 天 。 着 me 相关 处 各 玫 数 


区 和 千村 拷 庆 换行 标记 这 二 第 征文 本 ， 


Se 
也 有 卫 宗 记 : 行 雯 林 
ve 过 渤 捧 了 所 DE 
全 


CT Bae 
图 4-13 HTML 处 理 函 数 的 运用 


4.4.4 改变 字符 串 大 小 写 


有 时 在 比较 英文 字符 串 时 ， 只 要 求 比较 其 内 容 ， 而 对 其 是 否 大 小 写 不 做 要 求 ， 这 时 就 
需要 把 比较 的 对 象 转换 为 统一 的 大 小 写 格式 。 使 用 strtolower0 函 数 可 以 将 字符 串 全 部 转换 
为 小 写 ， 使 用 strtoupper0 函 数 可 以 将 字符 串 全 部 转换 为 大 写 。 例 如 : 


<?php 

echo strtolower("HelLO,WoRID"); // 输 出 "hello,world" 

echo strtoupper("hEllo,wOrLd"); // 输 出 "HELLO,WORLD" 
?> 


此 外 ， 还 可 用 ucfirst0 函 数 将 字符 串 的 第 一 个 字符 改 成 大 写 ， 用 ucewords() 函 数 将 字符 
串 中 每 个 单词 的 第 一 个 字母 改 成 大 写 。 例 如 : 


<?php 

echo ucfirst("hello world"); /| 输出 "Hello world" 
echo ucwords("how are you"); // 输 出 "How Are You" 
?> 


4.4.5 字符 串 拆 分 与 连接 


在 编程 过 程 中 , 有 时 需要 把 一 个 较 长 的 字符 串 按照 特定 的 条 件 分 割 成 多 个 字符 串 , PHP 

提供 了 explode0 和 str_split0 等 函数 来 完成 字符 串 的 分 割 。 
(1) explode0) 函 数 

explode0 函 数 可 以 用 指定 的 字符 串 分 割 另 一 个 字符 串 ， 并 返回 一 个 数组 。 其 语法 格式 
如 下 : 

array explode(string $separator , string $string [, int $limit ]) 

其 中 , 字符 串 $separator 是 分 割 字符 串 $string 的 边界 点 ， 此 函数 返回 由 字符 串 组 成 的 数 
组 ， 每 个 元 素 都 是 $string 的 一 个 子 串 。 参 数 $limit 是 可 选项 ， 如 指定 了 此 参数 ， 则 返回 的 
数组 中 包含 最 多 $limit 个 元 素 ， 并 且 最 后 那个 元 素 将 包含 string 的 剩余 部 分 。 例 如 : 
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和 


<?php 

$str= "使 用 空格 分 割 字符 串 ”; 

$array=explode(" ", $str); 

print_r($array); 。“// 输 出 Array ([0] => 使 用 [1] => 空 格 [2] => 分 割 [3] => 字 符 串 ) 


?> 

而 如 果 $limit 参数 是 负数 ， 则 返回 除了 最 后 的 Slimit 个 元 素 外 的 所 有 元 素 。 

(2) str_split0 函 数 

与 explode(0) 函 数 不 同 的 是 ，str_split0 不 以 某 个 字符 串 为 分 割 依 据 ， 而 是 以 一 定 长 度 为 


位 将 字符 串 分 割 成 多 段 ， 并 返回 由 各 段 组 成 的 数组 。 其 语法 格式 如 下 : 


array str_split(string $string , [, int $lengh ]) 
其 中 ，$string 为 要 分 割 的 字符 串 ， 可 选 参数 $lengh 是 分 割 的 单位 长 度 〈 默 认 的 单位 长 


度 为 1) 。 


(3) implode(0) 函 数 
与 explode() 和 str_split0 函 数 相反 , 使 用 implodeO 函 数 可 以 将 存储 在 数组 不 同 元 素 中 的 


字符 串 连 接 成 一 个 字符 串 。 其 语法 格式 如 下 : 


string implode(string $glue , array $pieces) 
其 中 ，S$pieces 为 保存 连接 字符 串 的 数组 ，$glue 是 用 于 连接 字符 串 的 连接 符 。 例 如 : 


<?php 

S$array=array("welcome","to","Cheng","du"); 

$str=implode(",",$array); // 使 用 逗号 作为 连接 符 

echo $str; // 输 出 " welcome, to, Cheng, du " 
?> 


下 面 举例 来 说 明 以 上 函数 的 用 法 及 区 别 ， 程 序 如 下 : 


<?php 

$arr1=array("Apache","PHP","MYSQL"); 

print "<b> 数 组 内 容 :</b><br/>\n"; 

var_dump($arr1); 

S$strarr1=implode("-",$arr1); 

print "<br/>\in<b> 连 接 后 的 字符 串 :</b><br/>\n$strarr1<br/>\n"; 
$str = "苹果 ， 西 红 柿 ， 香 莫 ， 栗 ， 梨 子 ， 芒 果 "; 

echo " 原 字符 串 是 : <b>".$str."</b><br>"; 

echo "方式 一 .以 辟 号 为 分 割 符 分 割 字符 串 : <br>"; 

$arr1 = explode(", ",$str); 

echo "---\$arr1[0] 的 值 :".$arr1[0]."<br>"; 

echo "---\$arr1[4] 的 值 :".$arr1[4]."<br>"; 

echo "方式 二 .分 割 时 指定 limit 参数 : <br>"; 

S$arr2 = explode("，",$str,3); 

echo "---\$arr2[0] 的 值 :".$arr2[0]."<br>"; 

echo "---\$arr2[2] 的 值 :".$arr2[2]."<br>"; 

echo "---\$arr2[4] 的 值 :".$arr2[4]."<br>"; 

echo "方式 三 .str_split 函数 分 割 ， 且 采用 默认 单位 的 分 割 长 度 : <br>"; 
S$str2="this,that,they, what,here"; 
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echo " 原 字符 串 是 : <b>".$str2."</b><br>"; 
$arr3 = str_split($str2); 

echo "---\$arr3[0] 的 值 : ".$arr3[0]."<br> ; 
echo "---\$arr3[2] 的 值 : ".$arr3[2]."<br> ; 
echo "--\$arr3[4] 的 值 : ".$arr3[4]. "<br>“: 
echo "方式 四 .str_split 函数 分 割 ， 并 设置 分 割 长 度 为 2: <br>"; 
$arr3 = str_split($str2,2); 

echo "---\$arr3[0] 的 值 : ".$arr3[0]."<br> ; 
echo "---\$arr3[2] 的 值 : ".$arr3[2]."<br> ; 
echo "---\$arr3[4] 的 值 :".$arr3[4]."<br>"; 
?> 


以 上 程序 代码 在 浏览 器 中 的 显示 结果 如 图 4-14 所 示 。 


」 立 件 吧 ) 知 辑 华 )】 于 看 信 ) 收藏 于 区 工具 加 帮助 0 
这 收 枉 天 。 逢 子 入 刘 分 剖 与 连接 杨 


> string(6) “hpache” [1]=> string(3) “PHP” [2]=> string(5) 


原 字符 串 了 西红柿 ， 香 兹 ， 和 苹 ， 梨子 ， 芒 果 
方式 一 . a 符 串 ， 


erlto 的 人 
一 -iarrl[4] 的 值 ， 
方式 二 . 和 多数 
arr2[0] 的 
一 -$e2[2] 的 值 ， 查 巷 ， 蔷 ， 琳 子 ， 
一 arr2[4] 的 值 ， 
方式 三 , str_split 函 数 分 齐 ， 且 采用 默认 单位 的 分 割 长 度 ， 
原 守 条 由 是 ， ee. that, they, what, here 


一 $arr3[4] 的 值 ， 
方式 四 . str. 六 1 二 示 分 贡 ， 并 设置 分 割 长 度 为 2， 
3[0] 的 值 ， 


一 $er3[4] 的 值 , 
bE [mm sl EE 


图 4-14 字符 串 分 割 与 连接 函数 


4.4.6 字符 串 查 找 


在 实际 编程 过 程 中 ， 经 常 需要 在 一 个 字符 串 中 查找 某 个 字符 串 或 者 某 个 子 串 。PHP 中 

用 于 字符 串 查 找 、 定位 的 函数 非常 多， 下 面 介绍 几 种 比较 常用 的 函数 。 
(1) substr0 函 数 

substr0) 函 数 的 语法 格式 如 下 : 

string substr(string str, Int start [, int length]) 

其 中 ， 参 数 str 用 来 指定 被 操作 的 字符 串 ， 参 数 start 用 来 指定 子 串 的 起 始 位 置 ， 如 默 
认 ， 表 示 从 第 一 个 字符 开始 ， 如 果 该 参数 为 负数 ， 则 从 原 字 符 串 末尾 向 前 数 start 个 字符 ， 
由 此 开始 取 子 串 ， 如 果 start 所 指定 的 位 置 超出 了 str 范围 ， 则 该 函数 返回 FALSE; 参数 
length 用 来 指定 子 字符 串 的 长 度 ， 如 默认 此 参数 或 者 该 参数 大 于 原 操作 字符 串 长 度 ， 则 返 
回 从 起 始 位 置 之 后 的 所 有 字符 。 

(2) stristr0 函 数 
该 函数 用 来 在 一 个 字符 串 中 查找 一 个 子 串 的 首次 出 现 , 在 查找 时 会 区 分 字符 的 大 小 写 。 
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其 语法 格式 如 下 : 
string stristr(string $haystack, string $needle) 
其 中 ,参数 $haystack 指定 原 字 符 串 ; 参数 Sneedle 表示 要 查找 的 子 字符 串 ， 如 果 它 不 是 
一 个 字符 串 ， 则 将 被 转换 为 一 个 整数 并 作为 一 个 普通 字符 来 使 用 。 如 果 在 字符 串 $Shaystack 
中 出 现 了 $needle， 则 返回 Shaystack 字符 串 中 从 $needle 第 一 次 出 现 的 位 置 开 始 到 $haystack 
字符 串 结束 处 的 字符 串 。 如 果 没 有 返回 值 ， 即 没有 发 现 Sneedle， 则 返回 FALSE。 
(3) strstr0 函 数 
strstr0) 函 数 的 功能 与 stristr0 函 数 基 本 相同 , 只 不 过 在 查找 子 串 时 不 区 分 字符 的 大 小 写 。 
需要 注意 的 是 该 函数 与 stristr0 函 数 外 形 上 的 区 别 〈 它 没有 字母 1) 。 其 语法 格式 如 下 : 
string strstr(string $haystack, string $needle) 
其 中 ， 参 数 的 含义 和 功能 与 stristr0 函 数 中 的 参数 相同 。 
(4) strrchr0 函 数 
该 函数 用 于 在 一 个 字符 串 中 查找 某 个 字符 串 的 最 后 一 次 出 现 ， 其 语法 格式 如 下 : 
string strrchr(string $haystack, string $needle) 
查找 时 ， 系 统 将 从 原 字符 串 右边 开始 查找 ， 如 果 在 字符 串 $Shaystack 中 出 现 了 S$needle， 
则 返回 Shaystack 字符 串 中 从 $needle 最 后 出 现 的 位 置 开始 到 $haystack 字符 串 结束 处 的 字符 
串 。 如 果 没 有 返回 值 ， 即 没有 发 现 Sneedle， 则 返回 FALSE。 
下 面 举例 比较 一 下 以 上 函数 的 用 法 ， 程 序 如 下 : 
<?php 
$str = " 春 眠 不 觉 晓 ,处 处 闻 啼 鸟 ,夜来 风雨 声 , 花 落 知 多 少 ."; 
echo " 原 字符 串 : <b>".$str."</b><br>"; // 按 各 种 方式 进行 截取 
S$str1 = substr($str,4); 
echo "从 第 4 个 字符 开始 取 至 最 后 :".$str1."<br>"; 
S$str2 = substr($str,6,4); 
echo "从 第 6 个 字符 开始 取 4 个 字符 : ".$str2."<br>"; 
$str3 = substr($str,-5); 
echo " 取 倒 数 5 个 字符 :".$str3."<br>"; 
S$str4 = substr($str,-7,4); 
echo "从 倒数 第 7 个 字符 开始 向 后 取 4 个 字符 :".$str4."<br>"; 
S$str5 = substr($str,-9,-3); 
echo "从 倒数 第 9 个 字符 开始 取 到 倒数 第 3 个 字符 为 止 :".$str5."<br>"; 
Semail="user@website.com"; 
S$domain=strstr($email,"@"); 
Print "从 电子 邮件 地 址 中 取出 域名 : {$domain}<br/>\n"; 
$stri=stristr("This is a big city","A"); 
Print "不 区 分 大 小 写 取 子 串 : {Sstri}<BR/>"; 
S$strr="This is a book, that is a desk"; 
$strrigth=strrchr($strr, "th"); 
print "从 原始 字符 右边 取出 子 串 : {$strrigth}"; 


?> 


程序 运行 结果 如 图 4-15 所 示 。 
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图 4-15 字符 串 的 查找 函数 举例 


4.4.7 ”字符 串 替换 


在 Web 程序 中 ,常常 需要 在 一 个 字符 串 中 替换 指定 的 内 容 ， 实 现 这 种 功能 的 函数 有 以 

下 几 种 。 
(1) str_replace0 函 数 

该 函数 的 语法 格式 如 下 : 

mixed str_replace(mixed $search , mixed S$replace , mixed 人 [; int &$count ]) 

str_replace0 函 数 的 功能 六 用 新 的 字符 串 Sreplace 蔡 换 字符 串 $subject 中 的 $search 字 
符 串 。$count 是 可 选 参数 ， 是 PHP 5 中 新 添加 的 ， 表 示 要 执行 的 替换 操作 的 次 数 。 该 函数 
中 ，$search、S$replace、$subject 以 及 函数 本 身 的 返回 值 都 是 mixed 类 型 ， 也 就 是 说 这 些 参 
数 可 以 是 多 种 类 型 ， 相 应 的 返回 值 也 可 以 使 多 种 类 型 ， 如 字符 串 、 数 组 等 。 例 如 : 


<?php 

S$str="| love you"; 

Sreplace="China"; 

$end=str_replace("you", $replace, $str); 

echo $end; // 输 出 "| love China " 
?> 


str_replace(0) 函 数 对 大 小 写 敏感 ， 支 持 多 对 一 替换 〈 即 可 以 将 多 个 不 同 的 字符 替换 为 同 
一 个 字符 ) 和 多 对 多 替换 〈 即 可 以 将 多 个 不 同 的 字符 替换 为 多 个 对 应 的 不 同 字符 ) ， 但 无 
法 实现 一 对 多 的 替换 。 例 如 : 


<?php 

$str="My name is John Smith"; 

$array=array("a","o","A","O","e"); 

echo str_replace($array, "",$str); // 多 对 一 的 替换 ， 输 出 "My nm is Jhn Smith" 
echo "<br/>"; 

S$array1=array("a","b","c"); 

$array2=array("d","e","f"); 

echo str_replace($array1,$array2, "abcdef"); // 多 对 多 的 替换 ， 输 出 "defdef" 

?> 


以 上 程序 在 正 浏览 器 中 的 运行 结果 如 图 4-16 所 示 。 
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图 4-16 字符 串 替换 函数 举例 


(2) str_irepalce() 函 数 
该 函数 与 str_replace0) 函 数 的 功能 基本 相同 ， 只 是 不 区 分 大 小 写 。 其 语法 格式 如 下 : 
mixed str_ireplace(mixed $search , mixed $replace , mixed $subject [, int &$count ]) 
其 中 ， 各 参数 的 功能 和 含义 与 str_replace0) 函 数 中 的 参数 一 致 。 
(3) substr_replace() 函 数 
该 函数 用 于 替换 子 串 的 文本 内 容 并 返回 替换 后 的 字符 串 。 其 语法 格式 如 下 : 
mixed substr replace(mixed str, string replacement, int start [, int length]) 
其 中 ， 参 数 str 表示 原 字 符 串 ;参数 replacement 为 指定 用 来 替换 原子 字符 串 的 新 字符 
串 ，start 用 来 指定 执行 替换 操作 的 起 始 位 置 。length 是 可 选 参数 ， 表 示 要 替换 的 长 度 ， 如 
果 不 给 定 ， 则 从 start 位 置 开始 一 直到 字符 串 结束 ; 如 果 length 为 0， 则 替换 字符 串 会 插入 
到 原 字符 串 中 ; 如 果 length 是 正 值 , 则 表示 要 用 替换 字符 串 替换 掉 的 字符 串 长 度 ; 如 果 length 
是 负 值 ， 表 示 从 字符 串 末 尾 开 始 到 length 个 字符 为 止 停止 替换 。 例 如 : 


<?php 

echo substr_replace("abcdefg","YES",3); // 输 出 "abcYES" 

echo substr_replace("abcdefg","YES",3,3); // 输 出 "abcYESg" 
echo substr_replace("abcdefg"," YES ",-2,2); // 输 出 "abcde YES " 
echo substr_replace("abcdefg"," YES ",3,-2); /| 输出 "abc YES fg" 
echo substr_replace("abcdefg"," YES ",2,0); // 输 出 "ab YES cdefg" 
?> 


4.4.8 ”字符 串 加 密 


通常 情况 下 ， 人 们 将 可 懂 的 文本 称 为 明文 ， 将 明文 转换 成 的 不 可 懂 的 文本 称 为 密 文 。 
把 明文 转换 成 密 文 的 过 程 就 叫做 加 密 。PHP 中 ,crypt0、md50 等 函数 可 实现 字符 串 的 加 密 。 

crypt0 函 数 的 语法 格式 如 下 : 

string crypt(string $str [, string $salt ]) 

其 中 ， 参 数 $str 是 需要 加 密 的 字符 串 ， 参数 $salt 是 一 个 位 字 串 ， 能 够 影响 加 密 的 暗 码 ， 


干扰 非法 人 员 识别 明文 ， 从 而 减少 被 破解 的 可 能 性 。 默 认 情况 下 ，PHP 使 用 一 个 2 字符 的 


DES 干扰 串 ， 如 下 列 程序 代码 : 


<?php 
$str=" 这 是 明文 "; 
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S$des="ab"; 

echo " 没 加 密 之 前 的 明文 是 :".$str."<br/>"; 
echo "加 密 后 的 密 文 :"; 

echo crypt($str,$des); 

2 


程序 的 运行 结果 如 图 4-17 所 示 。 
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图 4-17 字符 串 加 密 函 数 


crypt0 函 数 只 能 完成 单 各 的 加 密 功 能 ， 也 就 是 说 它 可 以 加 密 一 些 明 码 ， 但 不 能 够 将 加 
密 后 的 密 文 转换 为 原来 的 明码 。 因 此 ， 使 用 crypt0O 不 是 特别 安全 。 若 要 获得 更 高 的 安全 性 ， 
可 以 使 用 md50 函 数 。 该 函数 使 用 散 列 算法 对 指定 的 字符 串 进行 加 密 ， 其 语法 格式 如 下 : 

string mds(string str [,bool] raw_output]) 

其 中 ， 参 数 str 表示 待 加 密 的 字符 串 ; 参数 raw_output 是 可 选 参 数 ， 如 果 为 TRUE， 则 
md50 函 数 返 回 一 个 长 度 为 16 位 的 二 进 制 格式 的 摘要 ， 如 为 FALSE， 则 返回 长 度 为 32 位 
的 十 六 进 制 格式 的 摘要 ， 该 参数 的 默认 值 是 FALSE。 例 如 : 

<?php 

$str=" 我 是 明文 "; 


echo md5($stn); // 输 出 的 相应 密 文 是 "f51fbb37237ddd56b14299b9de277be4" 
?> 


4.5 ”时 间 日 期 函数 


PHP 中 的 所 有 时 间 都 是 UNIX 纪元 的 ,即日 期 用 从 1970 年 1 月 1 日 以 来 所 经 历 的 总 秒 
数 表示 。 当 一 个 时 间 函 数 调用 从 1970 年 1 月 1 日 零 时 开始 计 的 秒 数 时 ， 就 把 它 当 作 
(timestamp) 时 间 戳 。PHP 中 的 大 多 数 时 间 函 数 就 是 以 时 间 戳 为 参数 转换 成 各 种 格式 的 时 
间 形 式 。 


4.5.1 时 间 日 期 函数 总 览 


PHP 在 处 理 数据 库 中 时 间 类 型 的 数据 时 ， 经 常 需要 先 将 时 间 类 型 的 数据 转化 为 UNIX 
时 间 惟 后 ， 再 对 其 进行 其 他 后 续 处 理 。 另 外 ， 不 同 的 数据 库 系 统 对 时 间 类 型 的 数据 不 能 兼 
容 转换 ， 这 时 就 需要 将 时 间 转 换 为 UNIX 时 间 戳 ， 然 后 对 时 间 戳 进行 操作 ， 从 而 实现 不 同 
数据 库 系 统 间 的 跨 平台 性 。 
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表 4-5 列 出 了 相关 的 时 间 数 据 处 理 函 数 。 


函 数 名 


表 4-5 日 期 时 间 处 理 函 数 
函数 功能 描述 


checkdate 


检查 日 期 是 否 合法 


date 


返回 一 个 表示 时 间 的 字符 串 


date_ default timezone get 


取得 一 个 脚本 中 所 有 日 期 函数 所 使 用 的 默认 时 区 


date_ default timezone set 


设 定 一 个 脚本 中 所 有 日 期 函数 所 使 用 的 默认 时 区 


getdate 返回 一 个 数组 ， 其 中 包含 小 时 数 、 分 数 、 秒 数 

gettimeofday 取得 当前 的 时 间 

gmdate 格式 化 一 个 GMT/UTC 日 期 /时 间 

gmmktime 取得 GMT 日 期 的 UNIX 时 间 惟 

idate 将 本 地 时 间 日 期 格式 化 为 整数 

localtime 取得 本 地 时 间 

microtime 返回 一 个 字符 串 ， 由 当前 时 间 的 毫秒 数 + 空格 + 从 1970 年 开始 的 秒 数 
mktime 返回 指定 日 期 的 时 间 戳 ， 即 从 1970 年 1 月 1 日 到 指定 日 期 的 秒 数 


set_time limit 


strfime 
time 


规定 从 调用 此 函数 的 程序 语句 起 ， 程 序 必须 在 指定 秒 数 内 运行 结束 ， 超 时 
则 程序 出 错 退 出 

根据 区 域 设置 格式 化 本 地 时 间 / 日 期 

将 当前 系统 时 间 转 换 为 对 应 的 时 间 戳 〈 长 整数 ) 


下 面 介绍 几 种 常用 的 日 期 时 间 处 理 函 数 。 


4.5.2 date() 和 time() 函 数 


date() 函 数 用 来 将 一 个 UNIX 时 间 戳 格式 化 成 指定 的 时 间 / 日 期 格式 。 其 语法 格式 如 下 : 

string date(string $format [, int $timestamp ]) 

其 中 ,参数 $format 指定 了 转换 后 的 日 期 和 时 间 的 格式 ， 参数 $timestamp 是 需要 转换 的 
时 间 戳 ， 如 果 省 略 ， 则 使 用 本 地 当前 时 间 ， 即 默认 值 为 由 time0 函 数 返回 当前 系统 时 间 对 
应 的 时 间 戳 。 本 函数 比较 难 掌握 的 是 由 $format 参数 指定 的 日 期 格式 。 

表 4-6 列 出 了 data0 函 数 支 持 的 格式 字符 。 


表 4-6 date() 函 数 的 格式 字符 列表 


format 字符 返回 值 例子 
d 月 份 中 的 第 几 天 ， 有 前 导 零 的 两 位 数字 01~31 
D Mon 到 Sm 
下 月 份 中 的 第 几 天 ， 没 有 前 导 零 1~31 
1 星期 几 ， 完 整 的 文本 格式 Sunday 一 Saturday 
N ISO-8601 格式 数字 表示 的 星期 中 的 第 几 天 1 (星期 一 ) 一 7 (星期 天 ) 
S 每 月 天 数 后 面 的 英文 后 组 ， 用 两 个 字符 表示 st、nd、rd 或 也 ， 可 以 和 j 一 起 用 
Ww 星期 中 的 第 几 天 ， 数 字 表示 0 (星期 天 ) 一 6 (星期 六 ) 
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续 表 
format 字符 说 明 返回 值 例子 
世 年 份 中 的 第 几 天 0 一 366 
W ISO-8601 格式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开始 | 如 42 (当年 的 第 和 2 周 ) 
F 月 份 ， 完 整 的 文本 格式 ， 如 January 或 March January 一 December 
m 数字 表示 的 月 份 ， 有 前 导 零 01~12 
M 3 个 字母 缩写 表示 的 月 份 Jan 一 Dec 
n 数字 表示 的 月 份 ， 没 有 前 导 零 1 一 12 
和 给 定 月 份 所 应 有 的 天 数 28~31 
这 是 否 为 头 年 如 果 是 半年 为 1， 否 则 为 0 
证 4 位 数字 完整 表示 的 年 份 如 1999 或 2003 
y 两 位 数字 表示 的 年 份 如 99 或 03 
a 小 写 的 上 午 和 下 午 值 am 或 pm 
A 大 写 的 上 午 和 下 午 值 AM 或 PM 
B Swatch Internet 标准 时 000 一 999 
g 小 时 ，12 小 时 格式 ， 没 有 前 导 零 1 一 12 
G 十，24 小 时 格式 ， 没 有 前 导 零 0 一 23 
h 时 ，12 小 时 格式 ， 有 前 导 零 01~12 
H 时 ，24 小 时 格式 ， 有 前 导 零 00 一 23 
i 00~59 
s 00~59 
e 时 区 标志 如 UTC、GMT、Atlantic/Azores 
! 是 否 为 夏令 时 如 果 是 夏令 时 为 1， 否 则 为 0 
O 与 格林 尼 治 时 间 相差 的 小 时 数 如 +0200 
与 格林 尼 治 时 间 (GMT) 的 差别 ， 小 时 和 分 钟 之 间 ji 
用 冒号 分 隔 
T 如 EST、MDT 
光 时 区 偏 移 量 的 秒 数 。UTC 西边 的 时 区 偏 移 量 总 是 负 Se 
的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 的 
c ISO 8601 格式 的 日 期 2004-02-12T15:19:21+00:00 
r RFC 822 格式 的 日 期 Thu, 21 Dec 2000 16:01:07 +0200 
U 从 UNIX 纪元 开始 至 今 的 秒 数 time0 函 数 


例如 , 将 当前 系统 日 期 分 别 转换 成 英文 格式 和 中 国 传统 的 日 期 格式 ,其 实现 程序 如 下 : 


<?php 

echo date(jS-F-Y); // 将 当前 日 期 转换 为 :月 中 的 第 几 天 -英文 的 月 份 - 年 份 

echo date('Y-m-d'); // 输 出 的 时 间 格 式 为 :四 位 数 的 年 份 -两 位 数 的 月 份 -两 位 日 数 
echo date('| M ',strtotime(‘2008-08-08")); /输出 Friday Aug 

echo date("l",mktime(0,0,0,7,1,2000)); // 输 出 Saturday 

echo date('U'); // 输 出 当前 时 间 的 时 间 截 

?> 
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time0 函 数 用 来 获取 当前 时 间 的 UNIX 时 间 戳 , 它 返 回 的 是 一 个 整数 , 如 下 列 程序 代码 : 


<?php 

$tm= time(); 

echo "当前 时 间 的 UNIX 时 间 戳 为 : ".$tm; /显示 当前 计算 机 系统 时 间 所 对 应 的 时 间 戳 
?> 


4.5.3 strtotime() 函 数 


strtotimeO 函 数 用 于 将 字符 串 表 达 的 日 期 和 时 间 转 换 为 时 间 戳 的 形式 ， 其 语法 格式 如 下 : 

int strtotime(string $time [, int Snow ]) 

其 中 ， 参 数 $time 是 一 个 字符 串 ， 用 来 指定 一 个 具体 的 时 间 ， 参数 Snow 用 来 计算 返 
值 的 时 间 戳 ， 如 果 该 参数 默认 ， 则 使 用 当前 系统 时 间 的 时 间 戳 。 该 函数 接受 一 个 包含 美 
英语 日 期 格式 的 字符 串 , 并 尝试 以 now 参数 给 出 的 时 间 为 基础 , 将 其 解析 为 UNIX 时 间 戳 。 

例如 : 


于 加 


<?php 

echo strtotime('2010-3-31'); // 输 出 1269993600 
echo strtotime('2010-03-05 10:27:30); 。 // 输 出 1267784850 
echo strtotime("10 September 2010"); 。“ // 输 出 1284076800 
?> 


特别 提醒 : 如 果 采 用 两 位 数字 的 格式 来 指定 年 份 ， 则 年 份 值 0 一 69 表示 2000 一 2069， 
70 一 100 表示 1970 一 2000。 


4.5.4 getdate() 函 数 


使 用 getdate0 函 数 可 以 获取 日 期 和 时 间 信 息 ， 其 语法 格式 如 下 : 

array getdate([ int $timestamp ]) 

其 中 ， 参 数 Stimestamp 表示 是 要 转换 的 时 间 锥 ， 如 果 默 认 ， 则 使 用 当前 系统 时 间 所 对 
应 的 时 间 惟 。getdate0 函 数 根据 $timestamp 返回 一 个 包含 日 期 和 时 间 信 息 的 数组 , 数组 的 下 
标 和 值 如 表 4-7 所 示 。 


表 4-7 getdate() 函 数 返 回 数组 下 标 与 值 的 对 应 表 


键 名 说 明 值 的 例子 
seconds 秒 的 数字 表示 0~59 
minutes 分 钟 的 数字 表示 0~59 
hours 小 时 的 数字 表示 0~23 
mda 月 份 中 第 几 天 的 数字 表示 3 
wday 星期 中 第 几 天 的 数字 表示 0 (表示 星期 天 ) 一 6〈 表 示 星 期 六 ) 
mon 月 份 的 数字 表示 1~12 
ear 4 位 数字 表示 的 完整 年 份 如 1999 或 2003 
da -年 中 第 几 天 的 数字 表示 0 一 365 
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续 表 
说 明 值 的 例子 
be 政文 本 表示 Sunday 一 Saturday 
January 一 December 
系统 相关 ， 典 型 值 从 -2147483648 一 2147483647 


有 两 种 方法 可 以 获取 某 时 间 点 的 时 间 信息 , 一 种 方法 是 直接 获取 当前 系统 时 间 的 信息 ; 
另 一 种 方法 是 指定 某 时 间 字 符 串 ， 然 后 将 该 时 间 字 符 串 转换 为 对 应 的 时 间 戳 ， 再 根据 这 个 
时 间 戳 来 获取 时 间 信 息 ， 其 程序 代码 如 下 : 


<?php 

Sarray1=getdate(); 
S$array2=getdate(strtotime(‘2011-03-31')); 
print_r($array1); 

echo "<br/>"; 

print_r($array2); 

?> 


以 上 程序 代码 运行 后 的 页 面 如 图 4-18 所 示 。 
hp //localbost/phpstudy/ hep4-10. phy - Micreseft Taterse es 
文件 时) 编辑 E) 查看 中 区 (人 ) 工具 IJ) 几 ! 
Om:©O- Hamm vm © 


六 在 @ | 国 http://1ocslhost/phpstady/ chip4-10. php 


Array ( [seconds] = 5 [nirutes] => 39 [hours] => 9 [mday] => 31 
[ = =》2011 [yday] => 89 [weekday] =》 
》1301564375 ) 
Asey ( [econds] = ) 0 trinates] => 0 [hours] => 0 [nday] => 31 [wday] 
> 4 [mon] => 3 [year] =》2011 [yday] => 89 [weekday] => Thursday 
Tnenth] > Noreh 区 => 1301529600 


加 


厂 同 ret 


图 4-18 ”getdate0 函 数 的 使 用 
4.5.5 mktime() 函 数 


三 


strtotime(O) 函 数 类 似 ，mktimeO0 函 数 也 用 于 将 时 间 日 期 转换 为 时 间 戳 ， 其 语法 格式 
如 下 : 


int mktime([int $hour [, int Sminute [, int $second [, int $month [, int $day [, int $year]]]]]]) 

其 中 ,参数 Shour 表示 小 时 数 ， 参数 $minute 表示 分 钟 数 ， 参 数 $second 表示 秒 数 ， 参 数 
$month 表示 月 份 ， 参 数 $day 表示 天 数 ， 参 数 $year 表示 年 份 。 如 果 所 有 的 参数 都 为 空 ， 则 
默认 为 当前 系统 日 期 及 时 间 。 

例如 : 


<?php 
Stimenum1=mktime(0,0,30,8,12,2008); 1/1/2008 年 8 月 12 日 零 时 零 分 30 秒 
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echo $timenum1; 


echo "<br/>"; 


$timenum2=mktime(3,20,0,9,18,99); 
echo $timenum2; 


?> 


/1/1/1999 年 9 月 18 日 3 时 20 分 的 时 间 惟 937624800 


4.6 数学 函数 


// 输 出 2008 年 8 月 12 日 零 时 零 分 30 秒 所 对 应 的 时 间 戳 1218499230 


Web 程序 在 运行 过 程 中 有 时 需要 进行 数据 计算 ， 除 了 加 、 减 、 乘 、 除 之 外 ， 往 往 还 要 
求 最 大 值 、 最 小 值 、 绝 对 值 、 随 机 数 、 取 整 和 对 数值 等 。 这 些 操 作 都 可 以 通过 PHP 内 置 数 


学 函数 来 实现 。 


4.6.1 数学 函数 总 览 


PHP 中 的 数学 函数 非常 丰富 ， 几 乎 涵盖 了 所 有 的 数学 运算 。 表 4-8 列 出 了 


站 


用 的 PHP 


数学 函数 。 
表 4-8 常用 的 数学 函数 列表 

函 数 名 功能 描述 
abs 求解 绝对 值 
acos 求解 反 余弦 
acosh 求解 反 双 曲 余弦 
asin 求解 反正 弦 
asinh 求解 反 双 曲 正弦 
atan2 求解 两 个 参数 的 反正 切 
atan 求解 反正 切 
atanh 求解 反 双 曲 正切 
base_convert 在 任意 进 制 之 间 转 换 数 字 
bindec 二 进 制 转换 为 十 进 制 
ceil 进 一 法 取 整 
cos 求 余弦 
cosh 求 双 曲 余弦 
decbin 十 进 制 转换 为 二 进 制 
dechex 十 进 制 转换 为 十 六 进 制 
decoct 十 进 制 转换 为 八进制 
deg2rad 将 角度 转换 为 弧度 
exp 计算 e (自然 对 数 的 底 ) 的 指数 
floor 舍 去 法 取 整 
fmod 返回 除法 的 浮 点 数 余数 
getrandmax 显示 随机 数 最 大 的 可 能 值 
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续 表 
函 数 名 功能 描述 
hexdec 十 六 进 制 转换 为 十 进 制 
hypot 计算 一 直角 三 角形 的 斜 边 长 度 
is finite 判断 是 否 为 有 限 值 
is_infinite 判断 是 否 为 无 限 值 
is_nan 判断 是 否 为 合法 数值 
lcg value 组 合 线性 同 余 发 生 器 
log10 求 以 10 为 底 的 对 数 
log 求 自然 对 数 
max 找 出 最 大 值 
min 找 出 最 小 值 
mt_ getrandmax 显示 随机 数 的 最 大 可 能 值 
mt rand 生成 更 好 的 随机 数 
mt_srand 播 下 一 个 更 好 的 随机 数 发 生 器 种 子 
octdec 八进制 转换 为 十 进 制 
pi 得 到 圆周 率 值 
pow, 指数 表达 式 
rad2deg 将 弧度 数 转换 为 相应 的 角度 数 
rand 产生 一 个 随机 整数 
round 对 浮 点 数 进行 四 舍 五 入 
sin 求 正弦 
sinh 求 双 曲 正弦 
qrt 求 平方 根 
srand 播 下 随机 数 发 生 器 种 子 
tan 求 正 切 
tanh 求 双 曲 正切 


下 面 讲 述 几 种 常用 的 数学 函数 的 用 法 , 以 便 启 发 读者 在 编程 中 灵活 运用 各 种 数学 函数 。 


4.6.2 求 随机 数 的 rand() 函 数 


rand0 函 数 用 于 返回 一 个 随机 整数 ， 其 语法 格式 如 下 : 


rand( [int min, int max ]) 


其 中 ,参数 min、max 表示 所 产生 随机 数 的 取 值 范围 ,，min 表示 最 小 数 ，max 表示 最 大 
数 。 如 果 没 有 提供 可 选 参数 min 和 max, 则 rand0 返 回 0~RAND MAX 之 间 的 伪 随 机 整数 。 


在 Windows 平台 下 ，RAND_MAX 值 等 于 32768， 


数 的 调用 形式 是 rand(15,30)。 
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六 此， 如果 要 产生 大 于 32768 的 随机 数 ， 


就 必须 指定 参数 min 和 max。 例 如 ， 要 想 取得 15~30 (包括 15 和 30) 之 间 的 随机 数 ， 函 
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4.6.3 ”最 大 值 函数 与 最 小 值 函数 


max0) 函 数 用 于 在 两 个 数值 中 求 最 大 值 ， 所 用 函数 的 语法 格式 如 下 : 

max(number argl ,number arg2) 

或 在 数组 中 求 最 大 的 元 素 值 ， 其 函数 的 语法 格式 如 下 : 

max(array numbers [.array…]) 

如 果 仅 有 一 个 参数 且 是 数组 ，max0) 函 数 返回 该 数组 中 最 大 的 值 。 如 果 第 一 个 参数 是 整 
数 、 字 符 串 或 浮 点 数 , 则 至 少 需 要 两 个 参数 , 且 max0 函 数 返 回 这 些 值 中 最 大 的 一 个 , 此 时 ， 
PHP 会 将 非 数 值 的 字符 串 当 成 0, 如 果 参 数 中 的 值 都 是 0, 则 max0 函 数 返 回 最 左边 的 那个 。 

与 max() 函 数 对 应 ，min0 函 数 也 有 两 种 函数 形式 。 在 两 个 数值 中 求 最 小 值 ， 所 用 函数 
的 语法 格式 如 下 : 

min(number argl ,number arg2) 

在 数组 中 求 最 小 的 元 素 值 ， 其 函数 的 语法 格式 如 下 : 

min(array numbers [,array…]) 

同样 ， 如 果 仅 有 一 个 参数 且 是 数组 ，min0 函 数 返回 该 数组 中 最 小 的 值 。 如 果 第 一 个 参 
数 是 整数 、 字 符 串 或 浮 点 数 , 则 至 少 需要 两 个 参数 , 且 min0 函 数 返 回 这 些 值 中 最 小 的 一 个 ， 
此 时 ，PHP 会 将 非 数值 的 字符 串 当成 0， 如 果 参 数 中 的 值 都 是 0， 则 min0 函 数 返 回 最 左边 
的 那个 。 


4.6.4 ”ceil()、floor() 和 round() 函 数 


在 PHP 中 ， 对 某 数值 取 整 的 函数 主要 有 ceil0、floor0 和 round0 3 个 函数 。 
(1) ceil0 函 数 
该 函数 的 语法 格式 如 下 : 
ceil(float value) 
其 功能 是 返回 不 小 于 value 的 下 一 个 整数 ，value 如 果 有 小 数 部 分 ， 则 进 一 位 。 
(2) floor0 函 数 
该 函数 的 语法 格式 如 下 : 
floor(float value) 
其 功能 是 返回 不 大 于 value 的 下 一 个 整数 ，value 如 果 有 小 数 部 分 ， 则 将 value 的 小 数 
部 分 舍 去 取 整 。 
(3) round0 函 数 
该 函数 的 语法 格式 如 下 : 
round(float val [,int precision]) 
其 功能 是 返回 根据 给 定 的 精度 precision 进行 四 舍 五 入 后 的 结果 ， 即 是 返回 小 数 点 后 
precision 位 的 四 舍 五 入 结果 ，precision 可 以 是 负数 或 0 (默认 情况 下 ) 。 
下 面 通过 实例 来 综合 说 明 以 上 各 种 数学 函数 的 使 用 方法 。 
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<?php 
echo "随机 数 1:"."<br/>"; 
$s1 = rand(100,200); 
echo $s1."<br/>"; 
echo "随机 数 2:"."<br/>"; 
$s2 = rand(100,200); 
echo $s2."<br/>"; 
echo "随机 数 1 和 随机 数 2 中 的 最 大 值 :"."<br/>"; 
echo max($s1,$s2)."<br/>"; 
echo "随机 数 1 和 随机 数 2 中 的 最 小 值 :"."<br/>"; 


echo min($s1,$s2)."<br/>"; 


echo "对 小 数 3.214443 保留 2 位 小 数 的 四 舍 五 入 ".round(3.214443,2)."<br/>"; 


echo "对 小 数 3.214443 采用 进 一 法 取 整 :".ceil(3.214443)."<br/>"; 
echo "对 小 数 3.214443 采用 舍 去 法 取 整 :".floor(3.214443); 


?> 


以 上 程序 代码 运行 后 的 页 面 如 图 4-19 所 示 。 


hp /flocaldost/phpstody/chapt 12 php Biers 
| 文件 四 负 竹 G) 查看 W) 收藏 W) 工具 GD 帮助 
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随机 数 1 和 随机 数 2 中 的 最 大 值 : 

189 

随机 数 1 和 随机 数 2 中 的 最 小 值 : 

167 

对 小 数 3. 214443 保 留 2 位 小 数 的 四 舍 五 入 3. 21 


对 小 数 3. 214443 末 用 进 一 法 取 整 ，4 
对 小 数 3. 214443 采 用 洁 去 法 取 整 ，3 
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图 4-19 常用 的 PHP 数学 函数 


4.7 


PHP 中 提供 了 一 些 对 图 像 进行 编 


图 像 处 理 函 数 


得 处 理 的 函数 ， 这 些 函数 在 需要 动态 生成 图 像 、 自 动 


批量 处 理 图 像 等 方面 ， 能 给 PHP 网 站 开发 者 带 来 很 大 的 帮助 。 其 中 最 为 典型 的 应 用 为 随机 


图 形 验 证 码 、 图 片 水 印 以 及 数据 统计 


在 PHP 中 有 的 图 形 函 数 可 以 直接 使 用 ,但 多 数 需要 在 安装 了 GD2 函数 库 后 才能 使 用 。 


P 饼 状 图 和 柱状 图 的 生成 等 。 


在 Windows 平台 下 安装 GD2 库 很 简单 , 就 是 PHP 5 自 带 的 ext 目录 中 的 php_gd2.dll 文件 ， 


也 就 是 本 章 开 始 处 讲 到 的 图 4-1 所 示 


9 内容。 如 果 没有 ， 说 明 安 装 PHP 时 没有 安装 GD2 


库 ， 打 开 php.ini 文件 ， 查 看 文件 中 是 否 有 一 句 “:;extension=php gd2.dl11”， 如 果 有 ， 将 其 
中 的 “;” 去 掉 ， 再 将 文件 中 扩展 目录 extension_dir 的 值 设 置 成 PHP 的 ext 目录 所 在 的 完整 


路 径 ， 如 “extension dir= "E:/phpS/ext"”， 保 存 后 重启 Apache 即 可 。 
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4.7.1 用 图 像 处 理 函 数 绘制 PNG 图 形 


在 PHP 中 绘制 图 形 一 般 包括 4 个 步骤 : (1) 创建 一 个 背景 ，(2) 在 背景 中 绘制 图 形 
或 输入 文本 ; 3) 输出 图 形 ; 〈4) 释放 所 有 资源 。 由 于 绘制 图 形 的 函数 种 类 比较 多 ， 鉴 
于 篇 幅 有 限 ， 此 处 仅 举 一 个 简单 例子 让 读者 体会 一 下 此 类 函数 的 使 用 。 例 如 : 

<?php 

Simage=imagecreate(400, 400); 

S$background_color = imagecolorallocate($image, 255, 255, 255); 

$black=imagecolorallocate($image,0,0,0); 

imageline($image, 0,0,100,100,$black); 

header("Content-type: image/png"); 

imagepng($image); 

imagedestroy($image); 

Te 


本 程序 第 2 行 中 用 imagecreate0 函 数 创建 了 一 幅 图 像 ， 其 语法 格式 如 下 : 

imagecreate(int $x_size , int $y_size) 

其 中 ，$x_size 和 $y_size 两 个 参数 分 别 表示 图 像 的 宽度 和 高 度 ， 单位 为 像素 ， 并 返回 此 
图 像 的 数据 流 ， 存 放 到 $image 变量 中 。 

第 3 行 用 imagecolorallocate() 函 数 为 图 像 设置 了 白色 的 背景 色 。 其中, 第 1 个 参数 表示 
图 像 流 ， 第 2 一 4 个 参数 表示 RGB 色 值 。 第 4 行为 图 像 设置 了 黑色 的 背景 色 。 第 5 行 用 
imageline(0) 函 数 绘制 了 一 条 直线 ,并 设置 其 颜色 为 黑色 。 第 6 行 向 浏览 器 发 送 头 信息 ， 输 出 
PNG 图 片 。 第 7 行 输出 图 形 。 第 8 行 清除 资源 。 

本 程序 的 运行 结果 如 图 4-20 所 示 。 


图 4-20 绘制 图 形 的 函数 


4.7.2 用 图 像 处 理 函 数 制作 水 印 效果 


图 像 处 理 函 数 不 仅 可 以 处 理 PNG 格式 的 图 像 ， 还 可 以 把 图 像 输 出 为 jpg、sgi 等 格式 。 
它 不 仅 可 以 直接 创建 一 个 图 像 流 来 绘制 图 形 ， 还 可 以 将 现 有 的 图 片 作为 图 像 流 读 入 ， 然 后 
在 此 基础 上 对 图 像 进行 修饰 ， 如 加 上 水 印 效 果 等 。 这 种 功能 常用 来 防止 图 片 被 盗用 。 

例如 ， 下 面 这 个 程序 ， 将 在 原始 图 片 picturejpg 上 添加 一 个 水 印 网 址 〈wwvw. 
danyangnetworkcommany.com.cn) ， 代 码 如 下 : 
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<?php 

header("Content-type:image/jpeg "); 

Sim = imagecreatefromjpeg("picture.jpg"); 

$black = imagecolorallocate($im,0,0,0); 

$width=imagesx($im); 

Sheight=imagesy($im); 

imagestring($im,5,6,10," www.danyangnetworkcommany.com.cn", $black); 
imagejpeg($im); 

imagedestroy($im); 

?> 


本 程序 的 运行 结果 如 图 4-21 所 示 。 


| 疤 件 旭 乌拉 E 查看 扫 收 式 反 了 具 D 而 各 db 
tw Et 3 本 


图 4-21 制作 水 印 效 果 的 图 像 
4.8 自 定义 函数 


虽然 PHP 为 用 户 提供 了 大 量 的 功能 函数 , 但 在 某 些 情况 下 仍然 不 能 满足 用 户 的 个 性 化 
需求 。 为 此 ，PHP 为 用 户 提供 了 自 定义 函数 的 功能 ， 程 序 员 可 以 根据 自己 的 实际 需要 来 纺 
写 函数 代码 ， 其 编写 的 方法 非常 简单 。 


4.8.1 函数 的 定义 与 调用 
自 定义 函数 的 语法 格式 如 下 : 


function function name($arg], $arg2,…, $areN) { 


statements 
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return expr : 

} 

其 中 ，function_name 表示 要 创建 函数 的 名 称 。 给 函数 命名 时 ， 应 遵循 与 变量 命名 相同 
的 规则 ， 但 函数 名 不 能 用 美元 符号 〈$) 打头 。 函 数 名 可 以 是 以 字母 或 下 划 线 开头 后 面 跟 0 
个 或 多 个 字母 、 下 划 线 和 数字 的 字符 串 ， 且 不 区 分 大 小 写 。 需 要 注意 的 是 ， 函 数 名 称 不 能 
与 系统 函数 或 用 户 已 经 定义 过 的 函数 重 名 。$arg1 一 SargN 是 函数 的 参数 ， 通 过 这 些 参数 可 
以 向 函数 传递 信息 。 一 个 函数 可 以 有 多 个 参数 ， 它 们 之 间 用 逗号 阳 开 ， 且 都 是 可 选 的 。 参 
数 可 以 是 各 种 数据 类 型 ， 如 整 型 、 浮 点 型 、 字 符 串 以 及 数组 等 。 
statements 表示 在 函数 体 中 定义 的 执行 语句 ,包括 调用 函数 时 将 会 执行 的 代码 ， 这 段 代 
码 可 以 包括 变量 、 表 达 式 、 流 程控 制 语句 ， 甚 至 可 以 是 其 他 函数 或 类 定义 。retum 语句 用 于 
立即 结束 此 函数 的 执行 并 将 它 的 参数 作为 整个 函数 的 值 返 回 ， 如 果 后 面 不 跟 任何 参数 ， 则 
仅 终止 脚本 文件 而 不 会 返回 任何 值 。 return 是 语言 结构 而 不 是 函数 , 只 有 在 返回 的 函数 结果 
是 一 个 表达 式 时 才 需 要 用 括号 将 其 括 起 来 。 

例如 ， 下 面 的 程序 定义 了 一 个 名 为 funcl 的 函数 。 

<?php 

function func1($x,$y) 


if($x==$y) 
echo "x=y"; 
else if($x>$y) 
echo "x>y"; 
else 
echo "x<y"; 
} 
?> 
在 以 上 程序 代码 中 ，function 是 系统 关键 字 ， 用 来 定义 函数 ,在 此 函数 中 包含 了 两 个 参 
数 : $x 与 Sy， 然 后 在 函数 体内 定义 一 个 下 …else if…else 流程 控制 语句 ， 用 来 判断 参数 $x、 
$y 的 大 小 ， 最 后 输出 这 两 个 参数 的 比较 结果 。 


4.8.2 函数 的 参数 传递 

函数 的 参数 传递 方式 总 体 上 可 分 为 值 传递 方式 和 引用 传递 方式 ， 下 面 介绍 PHP 自 定义 
函数 的 参数 传递 形式 。 

1. 通过 引用 传递 参数 

默认 情况 下 ， 函 数 参数 的 传递 形式 是 值 传递 ， 这 意味 着 即使 在 函数 内 部 改变 参数 的 值 ， 也 
不 会 改变 函数 外 部 的 值 。 如 果 需 要 函数 修改 它 的 参数 值 ， 则 必须 通过 引用 传递 参数 。 若 要 函数 
的 一 个 参数 通过 引用 传递 ， 则 需要 在 函数 定义 中 该 参数 的 前 面 加 上 引用 符号 “&”。 例 如 : 


<?php 
function color(&$col) /定义 函数 color()， 其 中 参数 采用 引用 传递 方式 
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台 5 且 


乳 起 


{ 

$col="green"; 
Sclr="blue"; // 给 $clr 赋值 blue 
color($clr); // 调 用 函数 color()， 参 数 使 用 变量 $clr 
echo $clr; // 输 出 "green"， 表 明 原 变量 $clr 的 值 已 改变 
?> 


2. 设置 参数 的 默认 值 
定义 函数 时 ， 还 可 以 为 函数 的 参数 设置 默认 值 。 参 数 的 默认 值 必须 是 常量 表达 式 ， 不 
变量 、 类 成 员 或 函数 调用 。 默 认 值 的 数据 类 型 既 可 以 是 标量 类 型 ， 也 可 以 是 数组 和 


特殊 类 型 ， 如 NULL。 当 使 用 默认 参数 时 ， 默 认 参 数 的 位 置 必须 位 于 所 有 非 默认 参数 的 右 


侧 。 
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例如 : 


<?php 
function book($author, $newbook="PHP") 


echo "我 喜欢 的 书 是 ".$newbook. ", 作 者 是 :". $author; 


1 
?> 
下 面 的 例子 用 来 综合 说 明 函 数 中 参数 的 传递 方式 。 
<?php 
function pingfang(&$var) /通过 引用 传递 参数 
{ 
$var*=$var; 
function pingfang1($var) 
$var*=$var; 
function display_text($text,$font_name=" 宋 体 ) 
{ 
echo "<font face=\"{$font_name}\">{$text}</font>\n"; 
1 
$var=3; 
echo "调用 函数 pingfang 和 pingfang1 之 前 : \$var=$var<br>\n'"; 
pingfang1($var); 
echo "调用 函数 pingfang1( 值 传递 ) 之 后 : \$var=$var<br/>\n"; 
pingfang($var); 


echo "调用 函数 pingfang 之 后 : \$var=$var<br/>\n"; 
echo "<hr/>\n"; 

display_text(" 默 认 情 况 下 使 用 宋体 <br>\n ); 
display_text(" 现 在 的 字体 改 为 隶书 <br>\n"," 素 书 "); 


?> 


以 上 程序 运行 后 的 网 页 页 面 如 图 4-22 所 示 。 
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本 x 
上 」 立 任 下 | 编辑 左 ] 查看 加 工具 加 帮助 0 
| 


其 fers angl 
el 


用 台数 ping 
Wt 2 Sr 


默认 情况 下 使 用 宋体 


现在 的 字体 政 为 未 书 


沁 到 一 天 | 


图 4-22 ”函数 参数 的 传递 方式 
4.8.3 用 函数 的 同名 变量 实现 可 变 函 数 


在 PHP 语言 中 ， 如 果 一 个 变量 名 后 有 圆 括号 ， 则 PHP 将 寻找 与 变量 的 值 同名 的 函数 ， 
并 且 将 尝试 执行 它 。 这 就 是 变量 函数 的 概念 。 变 量 函 数 不 能 用 于 语言 结构 ， 如 echo、require、 
print、unset、isset、empty、include 等 语句 。 例 如 : 


<?php 
function func1() 


echo "这 是 由 函数 fun1() 输 出 的 文字 <br/>\n"; 
function func2($var) 

echo "这 是 由 函数 fun2() 输 出 的 内 容 :$var<br/>\n"; 
function func3($var1,$var2) 


echo "这 是 由 函数 fun3() 输 出 的 内 容 :$var1,$var2<br/>\n"; 
} 
Sfunc="func1"; 
Sfunc(); 
Sfunc="func2"; 
Sfunc(" 你 好 "); 
Sfunc="func3"; 
$func(" 我 爱 你 "," 中 国 "); 


?> 


该 程序 的 运行 结果 如 图 4-23 所 示 。 


上 廊 梓 四 连 枉 加 查看 图 收 意 赤 风 ， 工具 四书 助 人 0 
| 


这 是 由 函 教 fml 0 输出 的 文字 
这 是 由 函数 fun2() 葵 出 的 内 容 : 你 好 
这 是 由 陪 数 fum3 (和 葵 出 的 内 雁 :我 受 你 , 中 国 


[FF [EE 


图 4-23 变量 函数 
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4.8.4 变量 在 函数 中 的 使 用 

变量 作用 域 指 的 是 变量 定义 的 上 下 文 背景 ， 而 变量 在 函数 中 的 作用 域 规定 了 变量 的 生 
效 范围 ， 即 规定 了 某 变量 是 在 其 所 在 函数 体内 有 效 还 是 在 函数 体内 外 都 有 效 。 

1， 变量 的 作用 域 与 包含 文件 

在 这 里 顺便 补充 说 明 一 下 PHP 程序 中 的 包含 文件 语句 ， 用 这 类 语句 可 以 实现 在 一 个 
PHP 文件 中 包含 并 执行 指定 的 其 他 文件 的 程序 代码 ， 从 而 简化 代码 结构 ， 实 现 软件 的 重用 
性 。 包 含 文件 语句 主要 包括 include 语句 与 require 语句 。 它 们 的 语法 格式 如 下 : 

include filepath ; 


require filename ; 

其 中 ，filepath 是 一 个 字符 串 ， 表 示 被 包含 文件 的 路 径 。 当 程序 运行 到 包含 语句 时 ， 系 
统 会 自动 指向 被 包含 的 文件 并 执行 相应 的 代码 直到 代码 结束 ， 然 后 又 转 回 到 包含 语句 的 下 
一 条 语句 运行 。require 语句 与 include 语句 的 功能 相似 ， 区 别 是 : 当 找 不 到 文件 时 ，include 
语句 会 产生 一 个 警告 ， 而 require 语句 会 导致 一 个 致命 错误 。 

在 PHP 中 ， 多 数 变量 不 仅 在 当前 PHP 程序 中 有 效 ， 而 且 其 生效 范围 也 涵盖 了 include 
和 require 语句 中 引入 的 文件 。 例 如 : 

<?php 

$str1="a";; 


include "otherprog.php"; 
ye 


本 程序 的 第 3 行 包含 了 另外 一 个 PHP 程序 otherprog.php, 则 第 2 行 中 的 变量 $strl 也 将 
在 otherprog.php 文件 中 起 作用 。 


2. 局 部 变量 
在 用 户 自 定义 函数 中 定义 的 变量 ， 默 认 情况 下 ， 该 变量 将 仅 在 所 处 的 函数 体 范围 内 有 


效 ， 这 种 变量 称 为 局 部 变量 。 例 如 : 
<?php 
ET // 在 函数 体外 定义 的 变量 
function test() 
{ 
echo S$str1 // 函 数 体内 引用 的 局 部 变量 
} 
text(); // 不 会 产生 任何 结果 
?> 


3. 全 局 变量 


与 局 部 变量 不 同 ， 全 局 变量 指 的 是 在 函数 外 部 定义 的 变量 。 若 要 在 函数 内 部 使 用 全 局 
变量 ， 可 以 先 使 用 global 关键 字 对 其 声明 ， 然 后 就 可 以 在 函数 体内 访问 它 了 。 例 如 : 
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<?php 

$NO1=2; 

$NO2=8; 

function total() 

{ 
global $NO1,$NO2; 
$NO2=$NO1+$NO2; 

} 

total(); 

echo $NO2; /将 输出 计算 结果 为 10 


全 


4. 静态 变量 

所 谓 静态 变量 ， 就 是 使 用 关键 字 static 定义 的 变量 。 它 仅 在 局 部 函数 体 中 存在 ， 当 程序 
执行 离开 函数 作用 域 时 ， 其 值 并 不 会 丢失 ， 因 此 ， 当 下 次 引用 它 时 将 返回 最 近 一 次 被 赋 的 
值 。 例 如 : 


<?php 
function Exam() 


Static $a=0; 
echo $a."<br/>"; 
$a++; 


} 

Exam();，// 输 出 0 
Exam();，// 输 出 1 
Exam(); /输出 2 
?> 


以 上 程序 代码 运行 后 的 页 面 如 图 4-24 所 示 。 
[TO -IO 


BW hs /focalhosys ls? x 
| 文件 中 护 错 于 ) 查看 WW) 收 若 闪 () ] > 
这 中 半天 http://1ocalhost/phpbookse 


图 4-24 函数 中 静态 变量 的 使 用 


4.9 案例 剖析 : 图 像 验证 码 的 实现 


本 章 最 后 将 利用 PHP 语言 编写 一 个 图 像 验 证 码 的 实现 程序 。 程 序 中 ,将 综合 运用 到 本 
章 讲 到 的 大 多 数 函 数 ， 使 读者 进一步 掌握 PHP 常用 内 置 函数 和 内 置 数组 的 使 用 方法 。 
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用 户 在 登录 一 个 Web 系统 时 , 除了 要 求 输入 用 户 名 和 口令 之 外 , 为 了 防止 同一 个 用 户 在 
同一 时 刻 多 次 登录 ， 往 往 系统 还 要 求 用 户 输入 验证 码 。 验 证 码 是 在 用 户 登 录 页 面 时 随机 产生 
的 ， 下 面 就 具体 分 析 一 下 如 何 利 用 前 面 介 绍 的 PHP 函数 实现 此 功能 。 

使 用 验证 码 的 主要 目的 是 为 了 防止 网 络 黑客 恶意 灌水 ， 不 断 向 网 站 服务 器 发 送 一 些 垃 
圾 信息 ， 影 响 网 站 的 正常 运作 ， 因 此 要 在 保证 人 的 肉眼 能 正确 识别 验证 码 图 像 字符 的 前 提 
下 ， 尽 可 能 多 一 些 干 扰 因素 ， 如 在 图 像 中 加 入 一 些 分 布 不 均 的 黑 点 、 短 横 线 等 。 


4.9.2 程序 代码 分 析 


验证 码 图 像 程序 一 般 由 3 部 分 组 成 ， 一 部 分 是 位 于 后 台 的 验证 码 产 生 程序 ， 如 本 例 中 
的 createYZM.php 程序 ， 另 一 部 分 是 位 于 前 台 的 HTML 文件 ， 如 本 例 中 的 login.html 程序 ; 
最 后 是 用 于 验证 用 户 输入 的 验证 人 码 是 否 匹 配 的 PHP 程序 ， 如 本 例 的 correct.php 程序 。 
createYZM.php 程序 代码 如 下 : 


<?php 
$NO = rand(1000,9999); /随机 生成 一 个 4 位 数 的 数字 验证 码 
Header("Content-type: image/PNG"); 
Session_start(); 
$_SESSION["CheckNO"] = SNO; 
srand((double)microtime()*1000000); 
Simage = imagecreate(60,20); 
$black = ImageColorAllocate($image, 0,0,0); 
$gray = ImageColorAllocate($image, 200,200,200); 
imagefill($image,0,0,$gray); // 创 建 图 片 ， 定 义 颜 色 值 
S$style = array($black, $black, $black, $black, $black, $gray, $gray, $gray, $gray, $gray); 
imagesetstyle($image, $style); 
S$y1=rand(0,20); 
S$y2=rand(0,20); 
S$y3=rand(0,20); 
S$y4=rand(0,20); 
imageline($image, 0, $y1, 60, $y3, IMG_COLOR_STYLED); /随机 绘制 两 条 虚线 ， 起 干扰 作用 
imageline($image, 0, $y2, 60, $y4, IMG_COLOR_STYLED); 
for($i=0;$i<80;$i++) 
{ 
imagesetpixel($image, rand(0,60), rand(0,20), $black); // 在 画布 上 随机 生成 大 量 黑 点 
} 
S$strx=rand(3,8); 
for($i=0;$i<4;,$i++){ 
S$strpos=rand(1,6); 
imagestring($image,5,$strx,$strpos, substr($NO,$i,1), $black);// 将 4 个 数字 随机 显示 在 画布 上 
S$strx+=rand(8,12); 
1 
ImagePNG($image); 
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ImageDestroy($image); 
?> 


login.html 程序 代码 如 下 : 


<HTML> 

<HEAD> 
<TITLE> 图 形 验 证 码 的 实现 </TITLE> 
</HEAD> 

<body> 


<form action="correct.php" method="post" > 

<table align="center"> 

<tr><td> 

<img src=createYZM.php> 

</td></tr> 

<tr><td> 请 输入 上 面 显示 的 验证 码 : <input type="text" name="correctcode"></td><tr> 
<tr><td><input type=submit value=" 提 交 "></td></tr> 
</table> 

</form> 

</body > 

</HTML> 


correct.php 程序 代码 如 下 : 


<?php 
session_start(); 
$passcode=$_SESSION["CheckNO ]; 
$userlnput=$_POST["correctcode "]; 
if($passcode == $ userlnput){ 

echo "验证 码 匹 配 ! 通过 验证 !"; 
}else{ 

echo "你 输入 的 验证 码 不 匹配 ! 没 通过 验证 !"; 
} 


?> 


以 上 代码 为 完整 的 代码 , 其 中 包含 HTML 语言 ,在 浏览 器 中 查看 的 效果 如 图 4-25 和 图 4-26 
所 示 。 


FE = /Shttp://localhest/phpbooksource/ eerie -lolxl 
bE 和 

A N A | 3 0 Ea 避让 好 由 x 川 访 百 度 
OO Oe ES Se < 图 
CETTTTTTTTTTTTTE 悦目 是 文件 中 ”编辑 人 查看 WW) 收 送 天 4) 工具 CD) 帮助 0 


a 引 这 收藏 天 篇 http://localhost/phpbooksource/correct. php 
ALIEN [ 你 输入 的 验证 码 不 匹配 | 没 通过 验证 | 
E33 
J 
芋 绊 | 加 一 国 国 加 ED 


图 4-25 图 像 验 证 码 的 实现 图 4-26 图 像 验 证 码 验 证 程序 
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4.10 本 章 小 结 


本 章 着 重 介 绍 了 常见 的 数组 、 字 符 串 处 理 、 时 间 日 期 处 理 等 内 置 函数 的 功能 及 其 用 法 ， 
同时 还 介绍 了 几 种 用 法 及 功能 与 内 置 函数 相似 的 内 置 数组 。 在 本 章 最 后 ， 介 绍 了 如 何 综合 
利用 函数 和 内 置 数组 来 实现 图 像 认证 码 。 


4.11 练 习 题 


1. 列举 至 少 10 个 处 理 字 符 串 的 函数 ， 并 简要 说 明 它 们 的 功能 。 

2. 若 要 显示 的 时 间 格 式 为 “XxX xX X X 年 XX 月 XX 日 ”， 应 怎样 设置 date() 函 数 的 格 
式 字符 串 ? 

3. 在 用 户 自 定义 函数 中 ， 怎 样 定义 静态 变量 ? 它 有 什么 特点 ? 

4. 什么 是 局 部 变量 和 全 局 变量 ? 简 述 它们 有 何 区 别 。 

5. 列举 至 少 4 种 内 置 数组 ， 并 简要 说 明 它 们 的 功能 。 

6. 简 述 Session 与 Cookie 的 工作 原理 ， 并 说 明 它 们 有 什么 区 别 。 


4.12 上 机 实战 


设计 一 个 程序 ， 首 先 制作 一 个 如 图 4-27 所 示 的 表单 ， 并 将 客户 端 提交 的 “每 月 生活 费 
用 支出 表 ” 的 表单 数据 转换 为 如 图 4-28 所 示 饼 状 百分比 图 。 


股东 投资 情况 : 


图 4-27 表单 格式 图 4-28 饼 状 百分比 图 
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次 
东 
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在 PHP 程序 中 检查 文件 是 否 存在 
打开 和 关闭 文件 
写 入 和 读 取 文 件 
文件 的 复制 、 删 除 操作 
目录 的 创建 、 读 取 、 删 除 操 作 
文件 的 上 传 
本 章 导读 : 
PHP 中 有 很 多 文件 处 理 函 数 ， 其 功能 包括 对 文件 和 目录 进行 各 种 操作 ， 如 将 用 户 提交 
的 数据 保存 到 文件 中 ， 也 可 以 将 文件 包含 的 数据 读 取 到 网 页 上 ， 还 可 以 在 文件 中 添加 、 更 
新 数据 。 最 后 ，PHP 还 可 以 通过 $ FILE 及 其 他 内 置 数组 来 实现 用 户 文件 的 上 传 ， 并 进行 相 
关 处 理 。 


加 回回 网 罗 加 


5.1 文件 操作 


文件 操作 在 PHP 编程 中 具有 重要 地 位 。 很 多 情况 下 ， 用 户 要 对 普通 文件 进行 操作 ， 如 
读 取 文件 、 判 断 某 文 件 是 否 存 在 以 及 文件 存放 的 目录 位 置 等 。 


5.1.1 文件 的 基本 操作 方法 


在 对 文件 操作 之 前 ， 要 先 打开 文件 ， 然 后 才 可 以 读 取 和 写 入 文件 ， 文 件 操作 完毕 之 后 
还 要 关闭 文件 。 

(7 打开 文件 

打开 文件 要 使 用 内 置 函 数 fppen0， 其 语法 格式 如 下 : 

$fp= fopen(string filename, string mode ) 

需要 注意 的 是 ， 必 须 把 fopen0 函 数 的 返回 值 赋 给 一 个 变量 ， 如 $fp， 这 个 变量 代表 文件 
的 指针 。 其 中 ，filename 是 要 打开 的 文件 名 称 ， 必 须 为 字符 串 形式 。 如 果 filename 表示 的 
是 一 个 文件 的 路 径 ， 如 http://-.. 类 的 格式 ， 则 被 当成 一 个 URL， 此 时 fopenO 函 数 将 利用 所 
指定 的 协议 与 服务 器 连接 ， 文 件 指针 指 到 服务 器 返回 文件 的 起 始 处 。 如 果 PHP 认为 
filename 指定 的 是 一 个 本 地 文件 ， 将 尝试 在 该 文件 上 打开 一 个 流 。 必 须 确保 该 文件 能 
PHP 访问 ， 因 此 需要 确认 文件 包括 读 写 的 访问 权限 。mode 是 打开 文件 的 方式 ， 必 须 为 字 
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符 形式 ， 其 可 能 值 如 表 5-1 所 示 。 
表 5-1 文件 打开 的 方式 


参 数 值 含义 

这 .六 只 读 形式 ， 文 件 指针 指向 文件 的 开头 

0 可 读 可 写 文件 ， 指 针 指 向 文件 的 开头 
只 写 形式 文件 ， 指 针 指 向 文件 的 开头 ， 打 开 的 同时 清除 所 有 内 容 ， 如 果 文 件 不 存在 ， 
则 尝试 建立 文件 
可 读 可 写 文件 ， 指 针 指 向 文件 的 开头 ， 打 开 的 同时 清除 所 有 内 容 ， 如 果 文 件 不 存在 ， 
则 尝试 建立 文件 
追加 形式 文件 (只 可 写 入 ) ， 文 件 指针 指向 文件 的 最 后 ， 如 果 文件 不 存在 将 尝试 建立 
文件 
追加 形式 文件 (可 读 可 写 ) ， 文 件 指针 指向 文件 的 最 后 ， 如 果 文件 不 存在 将 尝试 建立 
文件 
写 入 方式 打开 , 如果 文 件 存在 则 打开 失败 , 不 存在 则 创建 。 如果 文件 已 存在 , 则 fopenO 
pi 调用 失败 并 返回 FALSE, 并 生成 一 条 E_WARNING 级 别 的 错误 信息 。 如 果 文 件 不 存在 
则 尝试 创建 它 。 此 选项 被 PHP 4 及 以 后 的 版 本 所 支持 ， 仅 能 用 于 本 地 文件 
读 写 方式 打开 , 如 果 文 件 存在 则 打开 失败 , 不 存在 则 创建 。 如果 文件 已 存在 , 则 fopenO 
“x+? 调用 失败 并 返回 FALSE, 并 生成 一 条 E_WARNING 级 别 的 错误 信息 。 如 果 文件 不 存在 
则 尝试 创建 它 。 此 选项 被 PHP 4 及 以 后 的 版 本 所 支持 ， 仅 能 用 于 本 地 文件 


如 下 面 这 个 小 程序 : 


<?php 
Shandle=fopen("abc.txt","r+"); /以 读 写 方式 打开 文件 ， 并 以 文件 流 的 形式 赋 给 $handle 
if($handle) // 如 果 文 件 流 存在 
echo "打开 成 功 "; 
else // 如 果 文件 流 不 存在 
echo "打开 文件 失败 "; 
> 


(2) 读 取 文件 

PHP 中 ， 读 取 文 件 需要 使 用 内 置 函 数 fread()。 该 函数 用 于 读 取 文件 的 内 容 ， 其 语法 格 
式 如 下 : 

$fc= fread(int Shandle, int $length) 

在 使 用 fread0 函 数 时 ， 必 须 将 其 返回 值 赋 给 一 个 变量 ， 如 $fc。 函 数 中 ， 参 数 $handle 
表示 fopen0 函 数 返回 的 文件 指针 ; 参数 $length 表示 希望 读 取 的 字 节 数 ,其 最 大 取 值 为 8192。 
在 读 完 $length 个 字 节 数 之 前 遇 到 文件 结尾 标志 (EOF) ， 则 返回 所 读 取 的 字符 ， 并 停止 读 
取 操 作 ， 在 读 取 文件 时 ， 如 果 不 确定 文件 的 大 小 ， 可 以 用 一 个 较 大 的 数字 来 替代 。 文 件 读 
取 成 功 将 返回 所 读 取 的 字符 串 ， 否 则 返回 FALSE。 

例如 ， 下 面 这 个 小 程序 : 


<?php 
Shandle=fopen("abc.txt", "rb"); // 打 开 一 个 本 地 的 二 进 制 文件 
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$stringcont=""; /将 字符 串 初始 化 为 空 
while(!feof($handle)) 1// 判 断 是 否 到 文件 末尾 
{ 
$data=fread($handle,8192); // 读 取 文 件 内 容 
$stringcont.=$data; // 将 读 取 到 的 字符 数据 赋 给 字符 串 
} 
echo $stringcont; // 输 出 内 容 
fclose($handle); /关闭 文件 
?> 


(3) 写 入 文件 
在 PHP 中 可 以 使 用 fwrire0 函 数 向 现 有 文件 内 写 入 数据 。 如 果 文 件 不 存在 ， 则 应 先 使 用 
fopen0 函 数 创 建 。 此 时 ， 文件 打开 方式 的 参数 值 应 是 “w”、“w+”、“a” 或 “a+”。 例如， 
下 面 的 代码 将 在 C 盘 example 目录 下 新 建 一 个 名 为 examl.txt 的 文件 。 
<?php 


Shandle=fopen("C:\example\exam1.txt", "w"); 
?> 


文件 打开 后 ， 向 文件 中 写 入 内 容 可 以 使 用 fwrite0 函 数 ， 其 语法 格式 如 下 : 

fwrite(resource $handle , string $string [, int $length]) 

其 中 ， 参 数 Shandle 是 fopen0) 函 数 返回 的 文件 指针 ，Sstring 是 将 要 写 入 到 由 $handle 所 
指定 的 文件 中 的 字符 串 数据 ，$length 是 可 选 参数 。 如 果 指 定 了 $length， 则 在 写 入 了 S$string 
中 的 前 $length 字 节 的 数据 后 停止 写 入 。 最 后 ，fwrite0) 函 数 将 返回 写 入 数据 的 字 节 数 。 

例如 ， 下 面 的 程序 : 


<?php 

Shandle=fopen("E:\TOOL\\abc.txt", "w+"); // 打 开 abc.txt 文件 ， 不 存在 则 先 创建 
$num=fwrite($handle," 这 是 新 添 内 容 ",16); /将 返回 的 写 入 字符 的 长 度 赋 给 变量 Snum 
if($num) 


echo " 写 入 文件 成 功 <br>"; 

echo " 写 入 的 字 节 数 为 ".$num." 个 "; 

fclose($handle); /关闭 文件 
} 
else 

echo "文件 写 入 失败 "; 
?> 


执行 以 上 程序 代码 后 ，abc.txt 文件 内 容 的 前 后 变化 如 图 5-1 所 示 。 


a [BR] 
文件 EE) 编辑 于) 格式 ) 查看 @) 帮助 0 文件 四 编辑 于 ) 格式 0) 查看 WW 帮助 0) 
abcd = 这 是 新 应 内 容 
efgh| 


图 5-1 利用 fwrite0 函 数 向 文件 写 入 新 内 容 
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| 天 让 四 | 名] http://1ecahest/phpstadyychaps_1_ php 


写 入 文件 成 功 
写 入 的 字 节 数 为 12 个 


Eg 二 地 Intranet 
图 5-2 程序 运行 结果 
(4) 关闭 文件 
文件 处 理 完毕 后 ， 需 要 使 用 fclose0 函 数 关 闭 文件 ， 其 语法 格式 如 下 : 
fclose(resource $handle) 
参数 $handle 为 要 关闭 的 文件 指针 (该 指针 必须 有 效 ) ， 如 果 关 闭 成 功 , 则 返回 TRUE， 
否则 返回 FALSE。 例 如 : 


<?php 
S$handle=fopen("D:\example\A.php","w"); /以 只 写 方式 打开 文件 
if(fclose($handle)) // 判 断 是 否 成 功 关闭 文件 
echo "关闭 文件 成 功 "; 
else 
echo "关闭 失败 "; 
?> 


5.1.2 文件 操作 的 重要 函数 


前 面 讲述 了 文件 的 打开 操作 、 读 写 操作 和 关闭 操作 ， 在 实际 编程 中 仅 使 用 这 些 函 数 往 
往 不 能 满足 开发 需要 ， 通 常 还 要 用 到 其 他 一 些 重要 的 文件 操作 函数 ， 如 表 5-2 所 示 。 
表 5-2 重要 的 文件 操作 常用 函数 


函数 功 能 
eet 返回 $filename 文件 的 类 型 。 可 能 的 值 有 fifo、char、 dir、 block、 link、 
file 和 unknown 
filesize(string $filename) 返回 $filename 文件 大 小 的 字 节 数 , 如 果 出 错 返 回 FALSE ， 并 生成 
-条 E_ WARNING 级 的 错误 
把 整个 $filename 文件 读 入 一 个 数组 中 , 文件 中 的 每 一 行 作为 数组 中 
file(string $filename) 


的 一 个 元 素 ， 操 作 时 ， 无 须 打 开 文 件 

读 取 $filename 文件 内 容 

如 果 由 $filename 指定 的 文件 或 目录 存在 并 且 可 读 则 返回 TRUE 

由 $filename 指定 的 文件 或 目录 存在 并 且 可 写 则 返回 TRUE 

读 取 $filename 文件 ， 无 须 打 开 此 文件 

删除 $filename 

如 果 由 $filenam 指定 的 文件 或 目录 存在 则 返回 TRUE, 否则 返回 FALSE 
从 文件 $filename 中 读 取 一 个 字符 


file_get_contents(string $filename) 


is_readable(string $filename) 
is_writable(string $filename) 
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函数 


续 表 
功 能 


feets(string $filename) 


| 从 文件 $filename 中 读 取 一 行 字符 


feof(string $filename) 


| 判断 文件 指针 是 否 达 到 文件 末尾 


filemtime(string $filename) 


| 读 取 文件 的 最 后 修改 时 间 


copy(string $src, string $targ) 


表 5-2 中 ， 每 个 函数 都 有 - 


和 “C:/TEMP/ABC.php” 是 等 价 的 ) ， 


将 $src 文件 复制 到 $targ 文件 中 
-个 表示 文件 名 的 参数 $filename， 它 包 
径 以 及 文件 名 本 身 。Windows 中 支持 “\” 和 “/” 作 为 路 径 分 隔 符 (如 “CN\TEMPWABC.php” 
但 UNIX 平台 只 支持 “/” 作 为 路 径 分 隔 符 ， 所 以 如 


果 想 使 编写 的 程序 不 加 任何 修改 就 能 移植 ， 建 议 使 用 “/” 作 为 文件 的 路 径 分 隔 符 。 


5.1.3 ”文件 操作 函数 的 综合 案例 


下 面 用 一 个 具体 案例 来 综合 演示 
要 函数 。 


<?php 
$handle=fopen("demo1 .txt", "r"); 
while(!feof($handle)) 


$char=fgetc($handle); 
echo ($char== "\n"? '<br>':$char); 


} 
Shandle=@fopen("demo1.txt","r"); 
if($handle) 


while(!feof($handle)) 


$buffer=fgets($handle); 
echo $buffer. "<br>"; 


} 

fclose($handle); 
} 
Sfilestring=file_get_contents("demo1 .txt"); 
echo S$filestring ."<br/>"; 
Sline=file("demo1.txt"); 
foreach($line as Sfile) 
{ 

echo $file. “<br>”; 
b 
Sfilename="demo1.txt"; 
Snum=filesize($filename); 
echo($num/1024). "KB"."<br/>"; 
Sfilename = '_notes/demo2.txt'; 


示 常 见 的 文件 操作 全 过 程 ， 其 中 将 要 用 到 前 面 所 讲 的 重 


1/ 判断 是否 到 文件 尾 


// 获 取 当 前 一 个 字符 


/打开 文件 


// 判 断 是 否 到 文件 末尾 


// 逐 行 读 取 文 件 内 容 


// 关 闭 文件 


// 将 文件 demo1.txt 中 的 内 容 读 取 到 数组 $line 中 
// 遍 历 $line 数组 


// 输 出 内 容 


// 计 算 文件 大 小 
/以 KB 为 单位 输出 文件 大 小 
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if(file_exists($filename)) /检查 demo2 txt 文件 是 否 存 在 


echo "文件 存在 " ."<br/>"; 


} 
else 
echo "该 文件 不 存在 " . "<br/>"; 
. 
Sfilename = '_notes/demo2 .txt'; 
unlink($filename); /删除 磁盘 根 目 录 下 _notes 目录 中 的 demo2.txt 文 件 


$sourcefile="_notes/a.txt"; 
$targetfile="../phpstudy/b.txt"; 
if(copy($sourcefile, $targetfile)) 


echo "文件 复制 成 功 !"; 


?> 


以 上 程序 代码 运行 后 ， 在 下 浏览 器 中 得 到 的 结果 如 图 5-3 所 示 。 
/文件 操作 函数 使 用 ~ Vindows Internet Explerer 
[DEC 


这 收藏 天 。 所 文件 欣 作 函数 使 用 | 国 | 


this is a example, welcome to PHP World. this is a example,welcome to PHP World. 
this is a example, welcome to PHP World. 

this is a example, welcome to PHP World. 

0. 0380859375KB 


文件 存在 
文件 复制 成 功 ! 


图 5-3 文件 操作 函数 
当然 ， 此 类 函数 还 有 很 多 ， 由 于 篇 幅 有 限 ， 这 里 不 再 一 一 介绍 ， 读 者 可 查阅 PHP 手册 


或 其 他 相关 资料 自行 学 习 。 


5.2 目录 操作 


通常 对 某 文件 进行 操作 时 需要 寻找 它 所 在 的 目录 路 径 ， 对 目录 的 操作 主要 是 利用 目录 


函数 来 实现 的 。 下 面 就 来 介绍 一 下 常用 的 目录 操作 函数 。 
5.2.1 创建 和 删除 目录 


使 用 mkdir0 函 数 可 以 根据 用 户 提供 的 目录 名 或 目录 的 全 路 径 创 建新 的 目录 。 创 建成 


功 ， 返 回 TRUE， 否 则 返回 FALSE。 其 语法 格式 如 下 : 


bool mkdir(string pathname [, Int mode]) 
其 中 , pathname 表示 要 创建 的 路 径 名 称 , mode 表示 创建 目录 时 设置 的 对 该 目录 读 写 权 
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限 。mode 由 4 位 数字 组 成 ， 第 一 位 为 0， 后 三 位 为 3 个 八进制 数 ， 每 一 个 八进制 数 指定 不 
同 用 户 对 该 文件 的 权限 。 第 一 个 八进制 数 代 表 文 件 所 有 者 的 权限 ， 第 二 个 八进制 数 代表 指 
定 组 (group) 的 权限 ， 第 三 个 八进制 数 指 定 其 他 所 有 人 的 权限 (public) ， 每 一 个 数字 都 
包含 读 、 写 和 执行 3 种 权限 〈 其 权限 值 分 别 为 1、2、4) ，3 个 值 相 加 就 是 某 个 用 户 对 某 个 
文件 的 权限 。 例 如 ， 如 果 人 允许 目录 创建 者 有 读 、 写 和 执行 的 权限 ， 本 组 人 员 只 有 读 和 执行 
的 权限 ， 其 他 人 员 仅 有 读 的 权限 ， 则 可 以 把 mode 设 定 为 0751。 

例如 ， 下 面 这 个 程序 将 创建 一 个 只 有 创建 者 才 具 有 读 、 写 和 执行 权限 的 目录 ， 其 他 用 
户 没 有 任何 访问 权限 。 


<?php 

if(mkdir("./directory",0700)) /在 当前 目录 中 创建 path 目录 
echo "创建 成 功 "; 

We 


如 果 要 在 PHP 代码 中 删除 指定 的 目录 , 可 以 使 用 rmdir0 函 数 来 实现 , 其 语法 格式 如 下 : 

bool rmdir(string dimame) 

该 函数 的 功能 是 删除 dimame 指定 的 目录 。 该 目录 必须 是 空 的 ， 如 果 目 录 不 为 空 ， 则 
需要 先 删 除 目 录 中 的 文件 后 才能 删除 目录 。 若 删除 成 功 则 返回 TRUE， 否 则 返回 FALSE。 
例如 : 


<?php 


mkdir("C:/dir1"); /在 当前 工作 目录 中 创建 dir 目录 
if(rmdir("C:/dir1")) // 删 除 dir 目录 

echo "删除 成 功 "; 
?> 


5.2.2 ”获取 和 更 改 当 前 目录 

在 PHP 中 , 可 以 通过 两 个 函数 来 获取 和 设置 当前 目录 , 即 getewd0 函 数 和 chdir0 函 数 。 
下 面 介 绍 这 两 个 函数 的 功能 和 用 法 。 

1. getcwd() 函 数 获取 当前 工作 目录 

getcewd0 函 数 的 语法 格式 如 下 : 

string getcwd(void) 

本 函数 无 需 参数 ， 其 作用 是 取得 当前 的 工作 目录 。 如 果 成 功 取得 ,返回 当前 工作 目录 ， 
否则 返回 FALSE。 

2. chdir() 函 数 改变 当前 工作 目录 

用 chdir0 函 数 可 以 改变 当前 目录 ， 其 语法 格式 如 下 : 


bool chdir(string directory ) 
使 用 chdir0 函 数 可 以 改变 当前 工作 目录 的 设置 ， 其 中 参数 directory 是 新 的 当前 目录 。 
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下 面 举例 来 曾 述 这 两 个 函数 的 具体 应 用 


o 


<?php 

echo getcwd()."<br>"; // 显 示 当 前 工作 目录 
@mkdir("../temp"); // 在 网 站 根 目录 中 建立 temp 目录 
@chdir(../ temp’); /设置 temp 目录 为 当前 工作 目录 
echo getcwd(); 

?> 


本 程序 的 运行 结果 如 图 5-4 所 示 。 


可 数 得 措 针 移动 函数 的 等 合 应 用 举例 -有 ic ES 
| 文件 四 中 本 看 WD) 收 豪 &) 工具 XY) 帮助 和 0 | 
| 旨 招 - 卓 - 辐 儿 让 时 Yex 加 | 全- 鼎 


随 证 加 他] http /1ocalhost/phpstudy/ chap5_3. php 


D:\Program Files\Apache Group\Apache2\htdocs\phpstudy 
D:\Program Files\Apache Group\Apache2\htdocs\temp 


EE 
图 5-4 chdir0 函 数 的 应 用 


5.2.3 读 取 目 录 内 容 


如 果 在 PHP 程序 脚本 中 要 获取 一 个 目录 中 的 内 容 ， 可 以 利用 readdir0 函 数 来 实现 。 该 
函数 的 参数 是 一 个 已 经 打开 的 目录 句柄 ， 在 每 次 调用 时 返回 目录 中 下 一 个 文件 的 文件 名 ， 
在 列 出 了 所 有 的 文件 名 后 ， 函 数 返 回 FALSE。 因 此 ， 该 函数 结合 while 循环 可 以 实现 对 目 
录 的 遍历 。 如 下 列 程序 : 


<?php 
S$dir="../phpweb/manage"; 
$dir_handle=opendir($dir); /打开 目录 句柄 
if($dir_handle) 
4 
// 通 过 readdir() 函 数 返 回 值 是 否 为 FALSE 判断 是 否 到 最 后 一 个 文件 
while(FALSE!==($file=readdir($dir_handle))) 


echo $file ."<br>"; // 输 出 文件 名 


4 
closedir($dir_handle); /关闭 目录 句柄 
1 


else 


echo "打开 目录 失败 !"; 
本 程序 的 运行 结果 如 图 5-5 所 示 。 
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EE 


| 


图 5-5 利用 readdir0 函 数 读 取 目录 内 容 

此 外 ，scandir0 函 数 也 有 与 readdir0 函 数 类 似 的 功能 ， 该 函数 的 功能 是 列 出 指定 路 径 中 
的 目录 和 文件 ， 语 法 格式 如 下 : 

array scandir(string $directory [, int $sorting_order [, resource $context ]]) 

其 中 ，$directory 为 指定 路 径 ; $sorting_order 为 目录 和 文件 的 指定 排列 顺序 ， 默认 是 按 
字母 升序 排列 ， 如 果 设 为 1 则 表示 按 字 母 的 降序 排列 ，Scontext 是 可 选 参数 ， 是 一 个 资源 
变量 ， 保 存 了 与 具体 操作 对 象 有 关 的 一 些 数据 。scandir0 函 数 运行 成 功 ， 则 返回 一 个 包含 指 
定 路 径 下 的 所 有 目录 和 文件 名 的 数组 ， 和 否则 返回 FALSE。 例 如 : 

<?php 

Sdir="../ phpweb/manage"; 

Sfile1=scandir($dir); 


Sfile2=scandir($dir, 1); 
if($file1==FALSE) 


echo " 读 取 失败 "; 
} 


else 
print_r($file1); 


人 

2 

以 上 程序 的 运行 结果 如 图 5-6 所 示 。 

需 提醒 读者 注意 的 是 ， 程 序 中 采用 了 两 种 方式 来 读 取 目 录 内 容 。 第 一 种 方式 是 按 目 录 
中 文件 名 的 升序 来 查看 文件 〈 见 第 3 行 代码 ， 即 “$filel=scandir($dir);”) ， 显示 效果 如 
图 5-6 中 的 第 1 一 7 行 所 示 ; 第 三 种 方式 是 按 目录 中 文件 名 的 降序 来 查看 文件 ( 见 第 4 行 代 
码 ， 即 “$file2=scandir($dir,1);”) ， 显 示 效 果 如 图 5-6 中 的 第 8 行 至 最 后 一 行 所 示 。 
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> Adnin Style. 

athcr modailc_ bj. 

fun_head. php [2] 
+ 


[07] dle 
botton. php [20] => Admir, 


Eb 


图 5-6 利用 scandir0 函 数 读 取 目 录 内 容 
5.2.4 ”解析 路 径 信息 
在 PHP 程序 脚本 中 , 利用 pathinfo0 函 数 可 以 返回 文件 所 在 的 目录 路 径 信息 ， 其 语法 格 


式 如 下 : 


array pathinfo(string directory [, int options]) 

其 中 ， 参 数 directory 表示 一 个 路 径 ，options 指定 要 返回 哪些 元 素 ， 包 括 PATHINO __ 

DIRNAME (目录 名 )、 PATHINFO_BASENAME (基本 文件 名 ) 和 PATHINFO_EXTENSION 
(文件 扩展 名 ) 。 本 函数 返回 一 个 数组 ， 该 数组 包括 dimame 〈 目 录 名 ) 、basename 〈 基 

本 文件 名 ) 和 extension (文件 扩展 名 ) 。 下 面 举例 来 说 明 如 何 利用 pathinfo0 函 数 对 文件 路 

径 进 行 解析 。 

<?php 

$dqianpage=$_SERVER['SCRIPT_FILENAME]; /获取 当前 网 页 在 服务 器 中 的 地 址 

$path=pathinfo($dqianpage); 

echo "当前 网 页 存储 路 径 信息 解析 结果 : <br/>"; 

echo "完整 路 径 :".$dqianpage."<br/>"; 

echo "目录 名 称 ".$path["dirmame"]."<br/>"; 

echo "基本 文件 名 :".$path["basename"]."<br/>"; 


echo "文件 扩展 名 :".$path["extension"]."<br/>"; 
?> 


本 程序 的 运行 结果 如 图 5-7 所 示 。 


ls es 


全 守住 信 息 拓 村 二 地 
D:/Program Files/Apache Group/Apache2/htdocs/phpstudy/chap5-6. php 


人 和 /Program Files/Apache Group/Apache2/htdocs/phpstudy 
基本 文件 名 :chap5-6. php 
文件 扩展 名 :php 


图 5-7 文件 的 路 径 解析 函数 举例 
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其 中 ，$_SERVER[] 是 PHP 内 团 的 预定 义 数组 ， 用 于 获取 有 关 网 站 服务 器 的 信息 。 关 
于 预定 义 数组 在 第 4 章 已 作 了 介绍 ， 这 里 不 再 缆 述 。 


5.3 文件 上 传 的 实现 


所 谓 文件 上 传 ， 就 是 将 客户 端的 文件 复制 到 服务 器 端 。 有 了 文件 上 传 的 功能 ， 用 户 不 
仅 可 以 为 网 站 动态 添加 附件 ， 还 可 以 实现 网 站 中 相关 图 片 、Flash 动画 、 声 音 文 件 等 的 动态 
更 新 。 若 要 PHP 网 站 具有 上 传 文件 的 功能 ， 则 首先 应 在 其 php.ini 配置 文件 中 开启 
file_uploads， 即 设置 为 “file_uploads = On”， 还 要 设置 上 传 文件 所 使 用 的 临时 目录 upload_ 
tmp_dir， 如 设置 为 “upload tmp_dir ="e:\php5\uploads\"”， 最 后 设置 上 传 文件 的 最 大 容量 
值 upload max filesize。 系 统 默认 的 最 大 容量 值 是 2MB， 如 要 设置 更 大 的 容量 (如 SMB) ， 
则 需要 对 upload max filesize 重新 赋值 ， 如 upload max filesize=SM。 


5.3.1 创建 文件 域 


实现 文件 上 传 功能 的 前 提 是 要 在 客户 端 网 页 上 创建 一 个 表单 ， 并 且 表 单 上 要 添加 若干 
文件 域 ， 以 方便 用 户 选择 本 地 磁盘 上 的 文件 进行 上 传 ， 文 件 域 相当 于 文本 框 ， 用 于 输入 上 
传 文件 在 本 地 磁盘 上 存放 的 位 置 。 与 普通 文本 框 不 同 的 是 ， 在 文件 域 旁 边 通常 有 一 个 “ 浏 
览 ” 按 钮 。 在 HIML 语言 中 ， 用 input 标记 创建 一 个 文件 域 ， 语 法 格式 如 下 : 

<input type="file" name="string" size="int" maxlength="int"> 

其 中 , name 属性 指定 文件 域 的 名 称 , size 属性 指定 文件 名 输入 框 最 多 能 显示 的 字符 数 ， 
maxlength 属性 指定 文件 域 最 多 可 容纳 的 字符 数 。 


5.3.2 单个 文件 的 上 传 


在 文件 上 传 过 程 中 ， 往 往 要 用 到 预定 义 数组 $_FILES， 它 是 一 个 二 维 数 组 ， 包 含 了 所 
有 要 上 传 文件 的 信息 。 如 果 HTML 表单 中 的 文件 域名 称 为 fle， 则 上 传 后 的 文件 信息 可 以 
使 用 以 下 形式 获取 。 
口 $_FILES['file'][mame']: 客户 端 上 传 的 源 文件 名 。 
口 $ FILES[file][type]: 上 传 文件 的 类 型 ， 需 要 浏览 器 提供 该 信息 的 支持 。 常 用 的 值 
包括 : “text/plain ”表示 普通 文本 文件 “image/sgif” 表 示 GIF 图 片 ; “image/pjpeg” 
表示 JPEG 图 片 ，“application/msword” 表 示 word 文件 ， “text/html” 表 示 html 
格式 的 文件 ，“application/pdf” 表 示 PDF 格式 文件 ，“audio/mpeg” 表 示 mp3 格 
式 的 音频 文件 ;“application/x-zip-compressed ”表示 ZIP 格式 的 压缩 文件 ;“application/ 
octet-stream” 表 示 二 进 制 流 文件 ， 如 EXE 文件 、RAR 文件 、 视 频 文件 等 。 
口 $FILES[file][tmp_ name]: 文件 被 上 传 后 在 服务 器 端 储存 的 临时 文件 名 。 
口 $FILES[file][size]: 已 上 传 文件 的 大 小 ， 单 位 为 字 节 。 
口 $_FILES['file"]['eror]: 错误 信息 代码 。 值 为 0 表示 没有 错误 发 生 ， 文 件 上 传 成 功 ; 
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值 为 1 表示 上 传 的 文件 超过 了 php.ini 文件 中 upload max filesize 选项 限制 的 值 ; 
值 为 2 表示 上 传 文件 的 大 小 超过 了 HTML 表单 中 规定 的 最 大 值 ; 值 为 3 表示 文件 
只 有 部 分 被 上 传 ， 值 为 4 表示 没有 文件 被 上 传 ， 值 为 5 表示 上 传 文件 大 小 为 0。 

上 传 文件 结束 后 ， 文 件 将 被 存储 在 临时 目录 中 ， 这 时 必须 将 其 从 临时 目录 中 删除 或 移 
动 到 其 他 地 方 。 不 管 是 否 上 传 成 功 ， 脚 本 执行 完 后 临时 目录 中 的 文件 肯定 会 被 删除 。 所 以 
在 删除 之 前 要 使 用 PHP 的 move_uploaded file(0) 函 数 将 它 移动 到 网 站 管理 员 指 定 的 位 置 , 此 
时 ， 才 算 完成 了 文件 上 传 。move_uploaded_file0 函 数 的 语法 格式 如 下 : 

bool move uploaded file(string $filename , string $destination) 

其 功能 是 检查 并 确保 $filename 文件 是 合法 的 上 传 文件 。 如 果 合 法 ， 则 将 其 移动 到 
Sdestination 指定 的 目录 下 ， 移 动 成 功 后 返回 TRUE; 如 果 $filename 不 是 合法 的 上 传 文件 ， 
则 不 做 任何 操作 ， 同 时 返回 FALSE。 例 如 : 

move_uploaded file($_FILES[myfile][tmp_name] "upload/index.txt") 


本 句 代 码 表示 将 由 表单 文件 域 控件 “myfile” 上 传 的 文件 移动 到 upload 目录 下 并 将 文 
件 命 名 为 “index.txt”。 

判断 是 否 是 合法 的 上 传 文件 ， 也 就 是 判断 是 否 是 通过 HTTP POST 上 传 的 ， 这 时 需要 
使 用 is_uploaded file0 函 数 ， 语 法 格式 如 下 : 

bool is uploaded file(string filename) 

如 果 filename 文件 是 通过 HTTP POST 上 传 的 ， 则 返回 TRUE， 和 否则 返回 FALSE。 这 
个 函数 用 来 避免 某 些 恶意 用 户 欺骗 脚本 ， 使 其 访问 一 些 根 本 无 法 访问 的 文件 。 例 如 ， 下 面 
这 个 程序 : 


<form enctype="multipart/form-data" action="" method="post"> 
<input type="file" name="myFile"> 

<input type="submit" name="up" value=" 上 传 文件 "> 

</form> 

<?php 

if(isset($_POST['up")) 

{ 


if($_FILES['myFile']['type']=="application/msword ") // 判 断 文 件 格式 是 否 为 Word 


if($_FILES['myFile'"]['error]>0) 1/ 判 断 上 传 是 否 出 错 
echo "错误 : ".$_FILES[myFile][error]; // 输 出 错误 信息 

else 

{ 
$tmp _filename=$_FILES[myFile][tmp_name']; /临时 文件 名 
$filename=$_FILES[myFile]rname]; /上 传 的 文件 名 
S$dir="_notes/"; // 上 传 后 文件 的 位 置 
if(is_uploaded _file($tmp_filename)) // 判 断 是 否 通 过 HTTP POST 上 传 
上 
/上 传 并 移动 文件 


if(move_uploaded _file($tmp_filename, "$dir.$filename")) 


td 
echo "文件 上 传 成 功 !"; 
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echo "文件 大 小 为 : " ($_FILES[myFilejrsize]/1024)."KB"// 输 出 文件 大 小 


else 
echo "上 传 文件 失败 !"; 
b 
b 
中 
else 
echo "不 好 意思 ， 你 上 传 的 文件 不 是 Word! "; 
有 
} 
?> 


其 中 ， 程 序 的 第 一 行 中 有 “enctype="multipartform-data"”， 要 实现 文件 的 上 传 功能 ， 
必须 在 表单 中 指定 enctype="multipartform-data"， 和 否则 服务 器 无 法 判断 程序 是 如 何 运行 的 。 


程序 运行 后 ， 单 击 “ 上 传 文件 ”按钮 ， 出 现 如 图 5-8 所 示 的 选择 上 传 文件 的 对 话 框 ， 文 件 
上 传 成 功 后 显示 的 页 面 如 图 5-9 所 示 。 
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0 最 晶 汪 上 主 口语 do 


EE 
0S Er 只 rr 


这 下 项 天 。 本 立 全 上 从 全 月 


站 | EX 人 


文件 上 传 成 功 1 文件 大 小 为 ，24. 5FB 
ns: mpizsse 本 


Yao [nx | 


图 5-8 单个 文件 的 上 传 举例 
5.3.3 多 个 文件 的 上 传 


图 5-9 单个 文件 上 传 成 功 


PHP 支持 同时 上 传 多 个 文件 并 将 它们 的 信息 自动 以 数组 形式 组 织 。 要 实现 此 功能 ， 需 
要 在 HTML 表单 中 动态 地 产生 多 个 上 传 文件 域 ， 其 文件 域 的 名 称 应 定义 为 形 如 userfile[] 的 
数组 形式 ， 这 需要 借助 于 客户 端的 JavaScript 来 实现 。 如 下 面 这 段 程 序 : 

<html > 

<head> 

<title> 同 时 上 传 多 个 文件 </title> 

</head> 

<body> 

<h2> 上 传 文件 实例 </h2> 

<script type="text/javascript"> 
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function add() /用 JavaScript 编写 的 函数 ， 用 来 实现 动态 生成 文件 域 


{ 
upload.innerHTML+=" 要 上 传 文件 :<input type=file name='userfile[]'><br>"; 
} 
</script> 
<form action="" method="post" enctype="multipart/form-data" name="form1"> 


<input type="hidden" name="MAX_FILE_SIZE” value="1048600" id="hiddenField" /> 
<div id=upload> 要 上 传 文件 : <input name='userfile[]' type="file" /> <br></div> 
<input type="button"” onclick="add()" value=" 添 加 要 上 传 的 文件 " /> ”// 在 按钮 上 添加 onclick 
行为 ， 并 将 此 行为 映射 到 add() 函 数 
<input type="submit" value=" 上 传 文件 " /> 
</form> 
<?php 
for($j=0;$j<sizeof($_FILES[userfile][error]):$j++) 
{ 
$ext=substr($_FILES[userfile][name'][$jl,strrpos($_FILES[userfile][rname'][$j] 
Supfile="_notes/"examfile_'.$_FILES['userfile]['name'][$j].time().$ext; 
iflis_uploaded _file($_FILES['userfile][tmp_name'"[$)])) 


{ 
if(Imove_uploaded file($_FILES[userfile][tmp_name'][$j],$upfile)) 
{ 
echo $j.' 问 题 在 于 :无 法 上 传 到 指定 路 径 '; 
exit; 
} 
else 


echo $j 问题 在 于 :上 传 的 文件 格式 不 符合 要 求 '; 
echo $_FILES['userfile]['name'][$)]; 
exit; 


} 
echo ' 第 '.9j.' 个 文件 上 传 文件 成 功 '."<br/>"; 
» 


i 
</body> 
</html> 


本 程序 的 运行 结果 如 图 5-10 和 图 5-11 所 示 。 


EEC aa 
[Os /rocaios vs ls) x le OOP ee | 


所 收藏 天 亿 同时 上 传 多 个 文件 由 雪夫。 也 Bai 上 信人 文件 Jel 
上 传 文件 实例 上 传 文件 实例 
要 上 传 文件 : | 本 说 要 上 传 文件 : [i 


要 上 传 文件 人 
要 上 传 文件 3 个 文 1 时 
要 上 传 文件 ，Gs Wavicat for ISOEE De 第 1 


裕 加 登 上 传 的 文件 | [ 上传 文件 


图 5-10 多 个 文件 的 上 传 图 5-11 多 个 文件 上 传 成 功 
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5.4 案例 剖析 : 基于 文件 名 的 目录 搜索 


众所周知 ， 计 算 机 可 以 存储 大 量 的 信息 资源 ， 这 些 信 息 资 源 往往 是 以 文件 形式 存放 到 
计算 机 存储 器 上 。 用 户 在 存储 和 检索 文件 时 ， 通 常 是 按 文 件 名 进行 存 取 的， 所 以 ， 下 面 来 
讲解 如 何 根据 文件 名 搜索 所 需要 的 文件 。 


5.4.1 程序 功能 介绍 


本 程序 要 实现 的 功能 是 能 够 按 文 件 名 进行 模糊 查询 ， 意 思 就 是 用 户 只 需 输入 文件 名 的 
个 别 关 键 字 ， 程 序 就 能 将 所 有 包含 该 关键 字 的 文件 查找 到 ， 并 将 搜索 结果 显示 出 来 。 


5.4.2 程序 代码 分 析 


根据 上 述 功能 分 析 ， 可 编写 如 下 代码 。 


<html> 

<head> 

<title> 基 于 文件 名 的 目录 搜索 引擎 </title> 

</head> 

<body> 

<form action="" method="post" enctype="multipart/form-data"> 
在 目录 中 搜索 ;<input type="text" name="txttarget" id="textfield" /> 
<input type="submit" value=" 搜 索 " /> 

</form> 

<hr/> 

<?php 

Sfolder="_notes"; 

$handle=dir($folden); 

$txttarget=$_POST[txttarget]; 

global $i,$p; 

$i=0; 

while($files[]=$handle->read()) 

{ 

$i++; 
} 
if(!IStxttarget) 


for($i=2;$i<count($files):$i++) 


{ 
echo "<a herf=$folder/$files[$i]>". $files[$i]."</a><br/>"; 
} 
$p=(count($files)-3); 
} 
else 
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for($i=2;$i<count($files):$i++) 


if(eregi($txttarget, $files[$1])) 


{ 
echo "<a herf=$folder/S$files[$i]>".$files[$i]."</a><br/>"; 
$p++; 
} 
Shandle->close(); 
echo $folder." 文 件 夹 中 符合 条 件 的 文件 数量 :".$p; 
?> 
</body> 
</html> 


上 述 代 码 用 到 了 前 面 讲 到 的 部 分 目录 和 文件 操作 函数 ， 还 用 到 了 eregi0 函 数 。 该 函数 
用 于 对 匹配 字符 串 进行 检测 ， 其 语法 格式 为 eregi(string pattem,string str)， 如 果 在 字符 串 str 
中 有 pattem 字符 串 ， 则 返回 TRUE， 否 则 返回 FALSE。eregi0 函 数 在 进行 比较 时 会 区 分 字 
符 的 大 小 写 ， 关 于 该 函数 的 详细 知识 ， 将 在 第 8 章 中 做 详细 讲述 。 

程序 的 运行 结果 如 图 5-12 所 示 。 


/C 基于 文件 名 的 目录 搜索 引擎 - Yindows Internet ERA 
EE [多 hs /locahos phostoay/Ton sr x eis 


这 收藏 天 只 基 于 文件 名 的 目录 搜索 引 生 | 


在 目录 中 搜索， [G8] 


chart9-2. php. mo 
chart9-3. php. mo 
chart9-4. php. mo 
chart9-5. php. mo 
chart10-1. php. mo 
chart10-2. php. mo 
chart10-3. php. mo 
chart10-6. php. mo 
chart10-7. php. mo 
chart10-8. php. mo 
chart4_13. php. mo 


notes 文 件 夹 中 符合 条 件 的 文件 数量 :11 


图 5-12 基于 文件 名 的 目录 搜索 
5.5 本 章 小 结 


本 章 介绍 了 常用 的 目录 和 文件 操作 函数 以 及 文件 上 传 的 实现 。 在 叙述 主要 内 容 时 ， 列 
举 了 很 多 实用 的 典型 案例 ， 力 求 使 读者 能 尽快 掌握 本 章 的 重点 知识 。 通 过 本 章 的 学 习 ， 读 
者 应 能 利用 PHP 对 文件 和 目录 进行 常见 的 操作 。 
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5.6 练习 题 
1. 简 述 PHP 中 的 文件 打开 方式 有 哪儿 种 ， 有 哪些 文件 操作 权限 ， 以 及 它们 之 间 有 何 
.怎样 检测 一 个 文件 或 目录 是 否 存在 ? 


2 
3. 将 数据 写 入 文件 有 哪 两 种 模式 ? 

4. 如 果 要 列 出 一 个 目录 中 的 所 有 文件 和 目录 ， 有 哪儿 种 方式 ? 
3 
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.如 果 获 取 上 传 的 文件 ?怎样 将 上 传 的 文件 移动 到 指定 的 位 置 ? 
.PHP 中 有 哪些 函数 可 以 实现 从 文本 文件 中 逐 行 读 取 数据 ? 


5.7 上 机 实战 


要 求 读者 根据 本 章 所 讲 的 知识 ， 使 用 之 前 学 过 的 数组 知识 及 其 他 方法 ， 编 写 一 个 计算 
投票 数量 的 程序 ， 其 运行 预期 效果 如 图 5-13 所 示 。 


总 统 候选 人 : 
e 张 三 
人 地 四 
人 王 五 


请 投票 


投票 完毕 ! 


张 三 的 票数 为 ，] 
李 四 的 票数 为 ，0 
王 五 的 票数 为 ，0 
总 票数 为 ，] 


图 5-13 计 票 程序 
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知识 点 : 


MySQL 数据 库 系 统 简 介 
MySQL 数据 库 系 统 的 安装 与 设置 
MySQL 中 的 数据 类 型 
结构 化 查询 语言 
MySQL 数据 库 管 理工 具 


本 章 导读 : 


动态 网 站 之 所 以 称 为 “动态 ”， 很 大 原因 是 因为 它 自始至终 离 不 开 数 据 库 。 为 了 更 好 
地 组 织 和 使 用 数据 ， 往 往 需要 将 数据 存储 在 服务 器 端的 后 台数 据 库 中 。 数 据 库 系统 其 实 就 
是 一 个 软件 系统 ， 通 过 该 系统 可 以 将 大 量 数据 进行 存储 和 管理 ， 目 前 在 业界 用 得 较 多 的 有 
Oracle、SQL Server 等 大 型 网 络 数据 库 以 及 Access、VFP 等 小 型 桌面 数据 库 。 而 对 于 网 站 
开发 来 说 ， 用 一 般 的 中 小 型 数据 库 系 统 就 足够 了 ， 其 中 ，MYySQL 是 目前 在 Web 应 用 领域 
(尤其 是 PHP 网 站 开发 中 ) 使 用 最 为 广泛 的 一 种 数据 库 。 


回回 罗网 加 


6.1 MySQL 数据 库 简 介 


MySQL 是 MySQL AB 公司 开发 的 一 种 开源 代码 的 关系 数据 库 管理 系统 ， 它 由 一 个 多 
线程 SQL 服务 器 、 多 种 客户 端 程序 、 管 理工 具 以 及 编程 接口 组 成 。 


6.1.1 Web 开发 与 数据 库 


利用 Web 进行 数据 处 理 是 以 现代 信息 技术 和 数字 化 网 络 通信 技术 为 基础 的 , 通过 计算 
机 信息 处 理 ， 可 以 实现 商品 销售 、 服 务 交 易 和 企业 信息 处 理 的 数字 化 。 随 着 Web 技术 的 发 
展 ,数据 库 技术 被 引入 到 了 Web 系统 中 ， Web 技术 与 数据 库 技术 的 完美 融合 ,使 得 程序 
员 可 以 开发 出 基于 Web 模式 的 数据 库 应 用 系统 (Web 数据 库 系统 ) ， 从 而 充分 发 挥 数 据 库 
高 效 的 数据 存储 和 管理 能 力 ， 为 广大 Intemet 用 户 提供 简单 、 快 捷 、 内 容 丰 富 的 动态 服务 。 

从 一 般 情况 来 看 ， 使 用 Web 数据 库 往 往 是 要 解决 数据 的 归纳 、 索 引 和 维护 等 问题 ， 
此 ， 一 般 选 择 流行 的 关系 型 数据 库 产 品 ， 如 Windows 2000 Server 下 的 SQL Server、UNIX 
下 的 MySQL、Oracle 等 。 这 些 都 是 功能 很 强 的 SQL 数据 库 ， 可 为 数据 管理 提供 一 个 标准 
而 坚实 的 接口 ， 因 此 常 被 用 作 Web 网 站 的 后 台数 据 库 。 
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6.1.2 MySQL 数据 库 概述 


MySQL 是 一 个 多 线程 SQL 服务 器 ， 采 用 客户 机 /服务 器 体系 结构 ， 客 户 机 通过 网 络 连 
接 到 MySQL 数据 库 服务 器 上 并 提交 数据 操作 请 求 ,MySQL 服务 器 用 于 监听 客户 机 的 请 求 ， 
再 根据 这 些 请 求 访问 数据 库 并 向 客户 机 提供 所 需要 的 数据 。 MySQL 服务 器 启动 后 ,客户 机 
才能 通过 网 络 连接 到 该 服务 器 。 

在 Windows 平台 上 ， 安 装 MySQL 时 通常 已 将 其 安装 为 Windows 服务 ， 当 Windows 
启动 或 停止 时 ，MySQL 也 随 之 启动 或 停止 。 除 此 之 外 , 用 户 也 可 以 使 用 服务 工具 来 启动 和 
停止 MySQL 服务 器 。 其 方法 是 : 右 击 桌 面 上 的 “我 的 电脑 ”图 标 ， 在 弹出 的 快捷 菜单 中 
选择 “管理 (G) ”命令 ， 然 后 在 弹出 的 树 形 目录 窗口 中 选择 “服务 和 应 用 程序 ”下 的 “ 服 
务 ” 选 项 ， 则 在 窗口 右 方 列 出 了 所 有 的 Windows 服务 ， 在 其 中 查找 并 选中 MySQL 选项 ， 
即 可 利用 工具 栏 上 的 图 标 来 启动 或 停止 MySQL 服务 器 ， 如 图 6-1 所 示 。 


人 AB C D A 一 启动 , B 一 停止 ，C 一 暂停 ，D 一 重启 


文件 四 换 作 可 看 W 窗口 中 | 
所 地 | 名 四 | 时 国名 | 加 | 


电 计算 机 管理 (本 寺 儿 服务 和 应 用 程序 \ 服 务 


CT FE 
[SLogical Disk Nonager Adninistrative Service 


EE LELEL CE 


图 6-1 用 服务 工具 启动 和 停止 MySQL 服务 器 


6.2 MySQL 数据 库 的 安装 与 系统 设置 


MySQL 在 Linux 和 Windows 平台 上 都 可 以 稳定 、 良 好 地 运行 ， 下 面 主 要 介绍 如 何在 
Windows 平台 上 安装 MySQL 数据 库 管理 系统 。 


6.2.1 下 载 MySQL 安装 包 


MySQL 的 官方 网 站 www.mysql.com 提供 了 3 种 可 供 下载 的 MySQL 5.0 安装 软件 包 ， 
用 户 可 以 根据 自己 的 实际 情况 进行 选择 。 
口 基本 安装 : 该 安装 软件 包 的 文件 名 类 似 于 mysql-essential-5.0.22-win32.mis， 包 含 
了 在 Windows 中 安装 MySQL 时 所 需要 的 最 少 文件 ， 并 包含 配置 向 导 在 内 ; 不 包 
含 嵌 入 式 服务 器 和 基准 套件 等 可 选 组 件 。 
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口 完全 安装 : 该 安装 软件 包 的 文件 名 类 似 于 mysql-5.0.22-win32.zip， 包 含 了 在 
Windows 中 安装 MySQL 时 所 需要 的 全 部 文件 ， 包 含 配置 向 导 、 榜 入 式 服务 器 和 
基准 套件 等 可 选 组 件 。 

口 ” 非 自动 安装 文件 ， 该 安装 软件 包 的 文件 名 类 似 于 mysql-noinstall-5.0.22-win32.zip， 
包含 完整 安装 包 中 除 配置 向 导 之 外 的 全 部 文件 。 由 于 它 不 包含 自动 安装 程序 ， 所 
以 用 户 必须 手动 进行 安装 和 配置 。 

建议 读者 选择 完全 安装 方式 。 在 安装 前 ， 先 到 MySQL 官方 网 站 上 下 载 mysql-5.0.22- 

win32.zip 文件 ， 然 后 双击 该 文件 即 可 进行 安装 。 


6.2.2 安装 MySQL 


将 mysql-5.0.22-win32.zip 安装 软件 包 下 载 到 本 地 磁盘 后 , 即 可 开始 安装 , 具体 步骤 如 下 ; 
(1) 将 mysql-5.0.22-win32.zip 解压 ， 得 到 一 个 setup.exe 文件 ， 双 击 此 文件 运行 安装 
程序 ， 出 现 如 图 6-2 所 示 的 安装 向 导 界 面 。 也 可 直接 双击 mysql-5.0.22-win32.zip 文件 ， 计 
算 机 将 自动 启动 setup.exe 安装 程序 。， 
(2) 单 击 Next 按钮 , 进入 安装 类 型 选择 界面 , 如 图 6-3 所 示 。 系统 默认 选项 为 Typical 
(典型 ) 安装 。 这 里 选择 第 3 种 类 型 即 Custom( 自 定义 ) 安装 ， 以 便 在 接 下 来 的 安装 过 程 
中 用 户 可 根据 实际 需要 自由 选择 安装 目录 。 


顺 wysQL Server 5.0 


‘Welcome to the Setup Wizard for MySQL 
Server 5.0 


Setup Type 
Choose the setup type that best suks your needs. 


The Setup Wizard wl install MySQL Server 5.0 release 5.0.22 
on your computer, To continue, cick Next 


三 Typical 
Hh Common program festures wdl be nstaled Reconmendedfor 
3S) general use, 
Complete 


WARNING: This progr am is protected by copyright aw. 


i Alprogram features wl be instaled, (Requires the most dsk 
"TY poee) 


图 6-2 安装 向 导 界 面 图 6-3 “安装 类 型 选择 ”界面 


(3) 单 击 Next 按钮 ， 出 现 “ 自 定义 安装 ”界面 ， 用 户 在 此 可 选择 要 安装 的 各 种 组 件 。 
因为 即使 安装 所 有 的 组 件 也 只 需要 25MB 的 空间 ,因此 建议 不 做 特别 的 改动 ,保持 默认 选择 即 
可 。 单 击 窗口 下 方 的 Change 按钮 可 选择 系统 的 安装 目录 ， 如 图 6-4 所 示 。 

(4) 单 击 Next 按钮 ， 系 统 将 提示 安装 准备 就 绪 ， 提 醒 用 户 确认 安装 ， 如 图 6-5 所 示 。 
确认 无 误 后 单 击 Install 按钮 ， 出 现 如 图 6-6 所 示 的 安装 进度 提示 窗口 。 安 装 完成 后 ， 将 出 
现 MySQL 注册 窗口 ， 提 示 创 建 一 个 MySQL 通行 证 或 登录 MySQL 通行 证 。 鉴 于 大 多 数 读 
者 安装 MySQL 仅 用 于 学 习 目 的 , 并 没有 MySQL.com 的 账号 和 密码 , 故 在 此 处 建议 读者 选 
择 Skip Sign-up 直接 跳 过 MySQL 通行 证 的 申请 和 注册 这 一 环节 (MySQL 官方 是 允许 的 ) ， 
如 图 6-7 所 示 。 
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个 mysQL Server 5.0 - Setup Wizara 
Custom setup 


Select the program features you want nstaled 


Clck on an icon in the list below to change how a feature is nstaled. 


| Documentation 
了 | Developer Components 


Server 5.0 - Setup 有 二 和 


Ready to Install the Program 
The weardis ready to begn nstalation_ 


FF you wank to review or change any of your instalation settings, cick Back, Cick Cancel to 
he wizard, 


Carrent Settings: 
:ep Type: 
um 


Destnation Folder: 


GlProgram FiesiMy5QLYMySQL Server 5.0\ 


图 6-5 MySQL 安装 设置 确认 


Installing MySQt Server 5.0 


The program features you selected are being instaled. Legn or este anew MySQL ,con account 


Please wak whie the Setup Wizard nstals MySQL Server 5.0. Th may take Ci an 
evra mes. ee 
rosee rae yoo ermeeeot ssbetths 
andecnglete the fadlowre three 


Seatus: 


new fles 

I FT Lognto MySQLcom 
Sec th cption Ff you aready have a My5QL com accourt, 
Peace pecfy your cgn rfomaton bebw', 


图 6-6 MySQL 安装 进度 图 6-7 MySQL 联机 注册 对 话 框 


(5) 单 击 Next 按钮 ， 随 后 出 现 安装 完毕 界面 ， 在 此 有 一 个 英文 提示 的 复 选 框 ， 询 问 
此 刻 是 否 进行 MySQL 服务 器 配置 ， 如 图 6-8 所 示 。 建 议 选中 此 复 选 框 ， 并 单 击 Finish 按钮 
以 启动 MySQL 服务 器 配置 向 导 。 


‘Wizard Completed 
Setup has finned nsealing WSQ. Server 5.0, Gdk Finih to 
it the wiearc, 


[7 Confgure the MySQL Server now 
eth rein poeets nopeed Wt otg 


a Wdows Soc 
sd Pe pment te rade 


图 6-8 MySQL 完成 安装 界面 
(6) 随后 将 出 现 配 置 MySQL 服务 器 实例 的 欢迎 界面 ， 单 击 此 界面 中 的 Next 按钮， 
出 现 选择 服务 器 配置 方式 的 窗口 ， 在 此 选择 Detailed Configuration (手动 精确 配置 ) 方式 ， 
如 图 6-9 所 示 。 单 击 该 窗口 中 的 Next 按钮 ， 这 时 出 现 要 求 用 户 选择 服务 器 类 型 的 界面 ， 共 
有 3 种 服务 器 类 型 : Developer Machine (开发 测试 类 型 ，MySQL 占用 很 少 资源 ) 、Server 
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Machine〈 服 务 器 类 型 ，MySQL 占用 较 多 资源 ) 和 Dedicated MySQL Server Machine〈 专 门 
的 数据 库 服 务 器 类 型 , MySQL 占用 所 有 可 用 资源 ), 读者 可 根据 实际 需要 进行 选择 , 在 此 ， 
建议 初学 者 选择 Server Machine 类 型 ， 如 图 6-10 所 示 。 


rver Instance Configuration MySQL Server Instance Configuration 
Configure the My5QL Server 5.0 server instance. Configure the my5QL Server 5.0 server instance, 


Please select a configuration type, Please select a server type, This wl nfiyence memory, disk and CPU usage. 


c 

(Detailed Configuration “Ths s a development machine, and many other appications wilbe 
Choose this configuration type to create the optimal server setup for run on &, MYSQL Server shoudd only use a minimal amount of 
this machine. Memory. 


Ce 


seror pplications wll bo rrring on ths poochine, Choose 
oe MySQL wi have medium 


Dedicated MySQL Server Machine 
We machino le doricatd to run tha MysoL Dat 
ens eh eb Mol env er saa 
ee 


图 6-9 MySQL 服务 器 配置 方式 的 选择 图 6-10 选择 配置 MySQL 服务 器 的 类 型 

(7) 单 击 Next 按钮 ， 接 下 来 要 求 用 户 选 择 MySQL 数据 库 的 大 致 用 途 。 其 中 ， 
Multifunctional Database 表示 多 功能 通用 型 ， Transactional Database Only 表示 服务 器 类 型 ， 
主要 用 于 事务 处 理 ， Non-Transactional Database Only 表示 非 事务 处 理 型 ， 主 要 做 一 些 简单 
的 监控 和 数据 储存 。 读 者 可 根据 自己 的 需要 进行 选择 ， 这 里 选择 Multifunctional Database 
(多 功能 通用 型 ) ， 如 图 6-11 所 示 。 单 击 Next 按钮 ， 出 现 配 置 InnoDB 数据 库 文件 的 存放 
位 置 ， 建 议 不 要 修改 ， 使 用 默认 位 置 。 单 击 Next 按钮 继续 安装 ， 出 现 如 图 6-12 所 示 的 数 
据 库 并 发 连接 数 选择 界面 ， 第 一 个 选项 Decision Support (DSS) /OLAP 支持 的 最 大 连接 数 
为 20; 第 二 个 选项 Online Transaction Processing (OLTP) 支持 的 最 大 连接 数 为 500; 第 三 
个 选项 Manual Setting 为 手动 设置 ,用户 自 己 输 一 个 连接 数 即 可 。 在 学 习 阶段 ， 建议 选择 第 
-种 ， 然 后 单 击 Next 按钮 继续 安装 。 


MySQL Server Instance Configuration MySQL Server Instance Configuration 
Configure the My5QL Server 5.0 server nstance， Configure the My5QL Server 5.0 server instance. 


Please select the database usage. Please set the appromate number of concurrenct connections to the server, 
Multifunctional Database © Decision Support (DSS)/OLAP 
General purpose databases, This wll optimize the server for the use ee 
旺 Ofte Tast Gansoctond imo storage enone nd the igh speed connections. A number of 20 connections 
MyISAM storage engne. 


3 Omiaed for ppleetion sorvers end ransoctional web 
Pe re ne ee 
OD MyISAM engine can stil be used. 


Non-Transactional Database Only 三 Manual Setting 
Suited For simple web applications, monitoring or logging applications Please enter the approximate number of concurrent connections, 
3 人 Only the non-transactional MyISAM < 3 = 
< Back Next > Cancel 
图 6-11 选择 MySQL 数据 库 的 用 途 图 6-12 MySQL 数据 库 最 大 连接 数 的 选择 


(8) 接 下 来 进行 数据 库 服 务 器 的 端口 配置 ， 如 图 6-13 所 示 。 该 界面 要 求 用 户 确认 是 
否 启用 TCP/IP 连接 。 如 果 启 用 ， 需 要 设 定 端口 ; 如 果 不 启用 ， 则 只 能 在 自己 的 机 器 上 访问 
MySQL 数据 库 。 为 了 学 习 方 便 ， 建 议 读者 选择 启用 TCP/IP 连接 ， 端 口号 Port Number 选择 
默认 值 3306。 单 击 Next 按钮 ， 进 入 数据 库 字 符 集 设置 界面 ， 如 图 6-14 所 示 。 这 一 步 的 设置 
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非常 重要 ， 其 中 ， 第 一 个 是 MySQL 默认 的 数据 库 语 言 编 码 即 西 文 编码 ， 第 二 个 是 多 字 节 的 
通用 utf8 编码 ， 二 者 都 不 是 中 国境 内 用 户 的 优先 选择 ， 因 此 推荐 读者 选择 第 3 个 即 自 定义 字 
符 集 ， 然 后 在 Character Set 下 拉 列 表 框 中 选择 或 输入 “gb2312”。 该 字符 集中 基本 上 包括 了 
所 有 常见 的 汉字 ， 只 有 这 样 ，MySQL 数据 库 才 能 正确 存储 和 显示 以 汉字 为 主 的 数据 信息 。 


Configure the mySQL Server 5.0 server natance， Configure the My5QL Server 5.0 server instance, 
Please set the networking options, Please select the default character set, 
[Enable TEP/IP Standard Character set 


Enable th to alow TCP/IP connections, When dsabled, only local 
connections through named pipes are alowed. 


Mahes Latinl the default charset, This character set fs sulted for 
Englsh and other West European languages， 


Port Number 到 © Best Support For 
Mahe UTFB the defal character set, This s the recommended 
character set for storing text In many different languages, 
Please set the server SQL mode. 


Manual Selected Default Character Set / Collation 
Please speaify the character set to use, 


Character Set: zsd 了 
mu | cme | 


[Enable Strict Mode 
This option forces the server to behave more ke a tradtional 
dakabase server. It is recommended to enable th option. 


| ee | 
图 6-13 MySQL 数据 库 的 网 络 设置 图 6-14 字符 集 设置 


(9) 单 击 Next 按钮 ， 接 下 来 要 确认 是 否 将 MySQL 安装 为 Windows 服务 。 如 果 安 装 
为 Windows 服务 ， 则 在 计算 机 启动 后 自动 启动 MySQL 数据 库 。 还 可 以 指定 服务 标识 名 称 
Service Name， 以 及 是 否 将 MySQL 的 Bin 目录 加 入 到 Windows 环境 变量 中 。 加 入 后 ， 就 
可 以 直接 使 用 Bin 下 的 文件 ， 而 不 用 指出 目录 名 ， 非 常 方 便 。 在 此 ， 读 者 不 妨 将 该 窗口 中 的 
所 有 选项 选中 ，Service Name 保持 不 变 ， 如 图 6-15 所 示 。 单 击 Next 按钮 ， 继 续 进行 安装 。 

(10) 接 下 来 设置 数据 库 超 级 管理 员 的 密码 。MySQL 安装 完成 后 会 默认 生成 一 个 用 户 
名 为 root 的 超级 管理 员 用 户 ， 密 码 为 空 ， 如 果 要 更 改 ， 就 需要 在 图 6-16 中 的 New root 
password 文本 框 中 输入 新 密码 ， 并 在 Confirm 文本 框 中 重复 输入 一 遍 ， 以 确认 密码 ， 防 止 
输 错 。 由 于 root 用 户 对 数据 库 拥有 完全 的 控制 权 ， 因 此 必须 牢记 该 密码 ， 若 是 忘记 将 很 难 
找 回 。 如 图 6-16 中 ，Enable root access from remote machines 复 选 框 表示 是 否 允 许 root 用 户 
在 其 他 的 机 器 上 登录 ， 为 了 数据 库 安全 起 见 ， 建 议 不 要 选择 ， 如 图 6-16， 单 击 Next 按钮 ， 
系统 提示 设置 步骤 完成 ， 单 击 Execute 按钮 使 设置 生效 ， 如 图 6-17 所 示 ， 稍 等 片刻 即 可 设 
置 成 功 ， 弹 出 如 图 6-18 所 示 的 窗口 ， 单 击 Finish 按钮 ， 结 束 数据 库 服 务 器 的 配置 。 


rver Instance Configuration My5QL Server Instance Configuration 
Configure the My5QL Server 5.0 server instance, Configure the My5QL Server 5.0 server nstance， 


Please set the Windows options. 


[Install As Windows Service 
This is the recommended way to run the My5QL server 
‘on Wndows. 


区 Launch the MysOL Seryer EM 
rectory in Windows PAT 
Check this option to ndlude the Containing the 
na 
so they can be caled from the command ine. pt oes nero 


< ce < | os] cm 


图 6-15 ”Windows 选项 设置 图 6-16 超级 管理 员 用 户 设置 
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SUL Server Tstwce Confi orci llr 四 


[SUL Server Tstwce ConGEAAGRAREE 
MysQL Server Instance Configuration MySQ Server Instance Configuration 
Configure the My5QL Servar 5,0 server ndtance Configure the MSQL Server 5.0servar nstance 
Processno confgurabon ,, 


Ready to execute ,,, 


Prepare configuration 
Write onfiguration fle (Gifrogran FileySOLMYSQL Suver S Dvny in) 


) pepare conhiguration 


) Write eonfiguration fle 


可 sat service 
可 Appy souriy setings 


) Start sarvice 


) Moply securly setings 


Please press [Execute] to start the configuration. 


Windows service MySQL installed， 
Service started successfully. 
Security settings applied. 
Press [Finish] to close the Wizard. 
图 6-17 准备 执行 配置 图 6-18 ”服务 器 配置 完成 


6.2.3 测试 MySQL 


由 于 在 安装 MySQL 过 程 中 已 经 将 其 安装 为 Windows 服务 ,因此 ， 当 Windows 启动 和 
停止 时 ，MySQL 也 会 随 之 启动 和 停止 。 用 户 可 以 通过 以 下 简单 步骤 来 测试 MySQL 数据 库 
是 否 已 启动 。 

(1) 选择 “开始 ”菜单 下 的 “运行 ”命令 ， 输 入 “cmd” 指 令 并 按 Enter 键 ， 即 可 打 
开 命令 提示 符 窗口 。 

(2) 在 命令 提示 符 的 光标 闪烁 处 输入 “mysql -uroot -p ”命令 并 按 Enter 键 , 会 出 现 Enter 
password 字样 的 提示 信息 , 即 要 求 输入 数据 库 超级 管理 员 的 密码 , 正确 输入 密码 后 按 Enter 键 。 

(3) 如 果 MySQL 数据 库 安装 成 功 并 已 启动 , 将 出 现 如 图 6-19 所 示 的 登录 成 功 的 欢迎 


信息 。 
EM 


991 
t Corp- 


new>mysql -u root -p 


nd witl 
versio 


”for help. Type ’\c’ to clear 上 


图 6-19 MySQL 数据 库 的 登录 
6.3 MySQL 数据 库 支持 的 数据 类 型 
MySQL 数据 库 系 统 可 存 入 多 种 类 型 的 数据 ， 数 据 库 中 的 数据 类 型 是 针对 字段 来 说 的 ， 
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也 称 为 “ 列 类 型 ”或 “字段 类 型 ”。 一 个 字段 一 旦 设置 为 某 种 类 型 ， 那 么 在 这 个 字段 中 就 
只 能 存 入 该 种 类 型 的 数据 ， 其 他 类 型 的 数据 将 视 为 非法 数据 。 下 面 介 绍 MySQL 数据 库 支 
持 的 数据 类 型 。 


6.3.1 数值 类 型 


数值 类 型 是 常见 的 数据 类 型 之 一 ,如 87 或 103.4 这 样 的 数据 就 称 为 数值 型 数据 .MySQL 
支持 科学 表示 法 ， 即 可 以 用 整数 或 浮 点 数 后 跟 “e” 或 “E”、“+” 或 “-” 及 一 个 整数 指 
数 来 表示 一 个 数值 。 例 如 ，1.24E+12 和 23.47e-1 都 是 合法 的 用 科学 表示 法 表示 的 数值 ， 而 
1.24E12 则 是 非法 的 (指数 前 未 指定 符号 ) 。 数值 型 的 数据 可 大 致 分 为 整 型 和 浮 点 型 两 大 类 。 


1， 整 型 数据 类 型 


MySQL 有 5 种 整 型 数据 类 型 ， 即 tinyint、smallint、mediumint、int 和 bigint。 这 5 种 
类 型 之 间 的 区 别 是 取 值 范围 不 同 ， 存 储 空间 也 各 不 相同 。 整 型 又 可 分 为 有 符号 型 和 无 符号 
型 两 种 ， 如 要 定义 无 符号 型 整数 ， 则 应 在 整 型 数据 列 后 加 上 UNSIGNED 属性 ， 此 时 该 字段 
可 以 禁止 输入 负数 。 

声明 整 型 字段 时 ， 程 序 员 可 以 为 它 指定 显示 宽度 ， 用 M (1 一 255) 来 表示 。 如 int(M)， 
当 M 为 5 时 ， 说 明 指 定 显 示 宽 度 为 5 个 字符 。 如 果 没 有 给 它 指定 显示 宽度 ，MySQL 会 为 
它 指定 一 个 默认 值 。 显 示 宽 度 定义 的 只 是 显示 宽度 ， 无 法 限制 该 整 型 数据 的 取 值 范围 和 占 
用 的 空间 。 例如， 一 个 定义 为 int(3) 的 整 型 字段 在 浏览 时 显示 3 位 数字 ， 但 仍然 会 占用 系统 
为 int 型 数据 定义 的 4 个 字 节 的 存储 空间 ， 最 大 值 也 不 会 是 999， 而 是 int 整 型 所 允许 的 最 
大 值 。 表 6-1 归纳 了 各 种 整 型 数据 的 使 用 方法 。 


表 6-1 MySQL 中 的 整 型 数据 


类 表示 范围 (有 符号 ) 描述 
tinyint 小 整数 值 
smallint 大 整数 值 
mediumint | 3 字 节 | -8388608 一 8388607 大 整数 值 
int -2147483648 一 2147483647 | ”0 一 4294967295 大 整数 值 
bigint “9223372036854775808 | 0~18446744073709551615 “| 极 大 整数 值 


9223372036854775807 


2. 浮 点 数据 类 型 


根据 精度 的 不 同 , 浮 点 数 有 float 和 double 两 种 。 它们 的 优势 是 可 以 表示 精确 度 非常 高 
的 小 数 。float 可 以 表示 绝对 值 非常 小 的 数 ， 如 1.17E-38， 即 0.000…0117“〈 小 数 点 后 面 有 
37 个 零 ) 。double 的 精确 度 更 高 ， 可 以 表示 绝对 值 小 到 约 2.22E-308 即 0.000…0222 (小 数 
点 后 面 可 以 有 307 个 零 ) 的 小 数 。float 类 型 和 double 类 型 占用 的 存储 空间 分 别 是 4 字 节 和 
8 字 节 。 表 6-2 归纳 了 各 种 浮 点 型 数据 的 使 用 方法 。 
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表 6-2 MySQL 中 的 浮 点 数 


表示 范围 (有 符号 ) 表示 范围 (无 符号 ) 
-3.402823466E+38 一 1.175 494351E-38、| 0、1.175494351E-38 一 
0 和 1.175494351E-38 一 3.402823466E+38 | 3.402823466E+38 
-1.7976931348623157E+308 一 
double ( 双 精 g 2.2250738585072014E-308、0 和 0、2.2250738585072014E-308 一 
度 浮 点 数 ) 2.2250738585072014E-308~ 1.7976931348623157E+308 
1.7976931348623157E+308 


< 注意 : 在 MySQL 中 还 可 以 定义 定点 数 ， 格 式 为 Decimal(M，D)， 其 中 M 表示 显示 的 
最 大 位 数 ， 小 数 点 和 符号 不 包含 在 M 中 ， 如 果 DD 是 0， 则 意味 着 该 数值 没有 小 


6.3.2 日 期 和 时 间 类 型 


日 期 和 时 间 类 型 包括 date、time、datetime、timestamp 和 year 等 几 种 类 型 。 每 个 时 间 
类 型 有 一 个 有 效 范围 和 一 个 “ 零 ” 值 ， 当 在 其 中 存 入 一 个 不 合法 的 数据 时 ，MySQL 将 使 用 
“ 零 ” 值 。 表 6-3 归纳 了 各 种 日 期 和 时 间 类 型 数据 的 使 用 方法 。 


表 6-3 MySQL 中 的 日 期 和 时 间 


类 型 | 大 小 ( 字 节 ) 表示 范 格 式 描 述 
date 3 字 节 1000-01-01~9999-12-31 | YYYY-MM-DD 表示 日 期 值 
表示 时 间 值 
time 3 字 节 -838:59:59 一 838:59:59 HH:MM:SS RE 
本 或 持续 时 间 
ear 1 字 节 1901~2155 YY 表示 年 份 值 
_ ee 1000-01-01 00:00:00 一 YYYY-MM-DD 表示 混合 日 期 
datetime 8 字 节 
9999-12-31 23:59:59 HH:MM:SS 和 时 间 值 
人 3 1970-01-01 00:00:00 一 Re 表示 混合 日 期 和 
和 YYYYMMDDHHMM ese PS 
a 2037-12-31 23:59:59 时 间 值 、 时 间 戳 


6.3.3 ”字符 串 类 型 


字符 串 可 以 用 来 表示 任何 一 种 值 ， 所 以 它 是 最 基本 的 类 型 之 一 。 根 据 所 存储 的 格式 不 
同 ， 可 将 其 分 为 普通 字符 串 类 型 、 二 进 制 字符 串 类 型 、TEXT 类 型 和 BLOG 类 型 。 表 6-4 
归纳 了 各 种 字符 串 类 型 数据 的 使 用 方法 。 


表 6-4 MySQL 中 的 字符 串 数据 类 型 


类 型 描 述 
char 定 长 字符 申 
vachar 变 长 字符 串 
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续 表 

类 型 大 小 描述 
tinyblob 255 字 节 不 超过 255 个 字符 串 的 二 进 制 字符 串 
tinytext 255 字 节 短文 本 字符 串 
blob 65535 字 节 二 进 制 形式 的 长 文本 数据 
text 65535 字 节 长 文本 数据 
mediumblob 16777215 字 节 二 进 制 形式 的 中 等 长 度 文本 数据 
mediumtext 16777215 字 节 中 等 长 度 文本 数据 
longblob 429967295 字 节 二 进 制 形式 的 极 大 文本 数据 
longtext 4294967295 字 节 极 大 文本 数据 

6.4 结构 化 查询 语言 简介 

SQL 是 Structured Query Language 的 缩写 ， 即 结构 化 查询 语言 。SQL 是 专 为 数据 库 而 


建立 的 操作 命令 集 ， 是 一 种 功能 齐全 的 数据 库 语言 。SQL 语言 结构 类 似 于 自然 语言 ， 功 能 
强大 ， 简 单 易学 ， 使 用 方便 ， 是 数据 库 操 作 的 基础 ， 目 前 几乎 所 有 的 数据 库 均 支 持 SQL。 


6.4.1 结构 化 查询 语言 简介 


SQL 是 结构 化 查询 语言 ， 它 是 使 用 关系 模型 的 数据 库 应 用 语言 。1982 年 ，ANSI ( 美 
国 国家 标准 局 ) 确认 SQL 为 数据 库 系 统 的 工业 标准 ， 并 在 1986 年 颁布 了 SQL-86 标准 。 该 
标准 的 出 台 使 SQL 作为 标准 关系 数据 库 语 言 的 地 位 得 到 了 加 强 。SQL 标准 几经 修改 和 完 
善 ， 目 前 最 新 的 SQL 标准 是 2003 年 制定 的 SQL-2003， 它 的 全 名 是 “International Standard 
ISO/TEC9075:2003，Database Language SQL ”。 

SQL 是 一 种 介 于 关系 代数 与 关系 演算 之 间 的 结构 化 查询 语言 ， 是 一 种 高 度 非 过 程 性 的 
关系 数据 库 语言 。 它 采用 的 是 集合 的 操作 方式 ， 操 作 的 对 象 和 结果 都 是 元 组 的 集合 ， 用 户 
只 需 知道 “ 做 什么 ”， 无 须知 道 “ 怎 么 做 ”， 因 此 SQL 语言 接近 于 自然 语言 ， A 
易学 易 用 。 同 时 ，SQL 语言 集 数据 查询 、 数 据 定 义 、 数 据 操纵 、 数 据 控制 为 一 体 ， 功 能 
大 , 因此 得 到 了 越 来 越 广泛 的 应 用 , 几乎 所 有 流行 的 关系 数据 库 系 统 (如 SQL Server、 DB2、 


Oracle、Access 等 ) 都 支持 SQL 语言 。 
6.4.2 ”常用 的 SQL 语句 用 法 


常用 的 SQL 语句 包含 4 个 部 分 : 数据 查询 语言 (SELECT) 、 数 据 操 纵 语言 (INSERT、 
UPDATE .DELETE)、 数 据 定 义 语言 (CREATE、ALTER、DROP) 和 数据 控制 语言 (COMMIT 
WORK、ROLLBACK WORK ) 。 在 没有 介绍 可 视 化 的 MySQL 数据 库 管理 工具 之 前 ， 用 户 
只 能 先 通过 命令 提示 符 界面 登录 MySQL 控制 台 ， 进 入 如 图 6-19 所 示 的 界面 ， 然 后 在 
“mysql>” 字 符 后 面 的 光标 处 输入 SQL 语句 ， 最 后 按 Enter 键 对 数据 库 进行 相应 操作 。 下 
面 介绍 一 些 常用 的 SQL 语句 。 
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1. 数据 库 的 创建 

使 用 CREATE DATABASE 语句 可 新 建 一 个 数据 库 ， 其 语法 格式 如 下 : 

CREATE {DATABASE | SCHEMA} [IF NOT EXISTS] db name [create specification 
[create specification| ...] create_specification: [DEFAULT] CHARACTER SET charset name 
| [DEFAULT] COLLATE collation name 

其 中 ,db_name 是 数据 库 名 称 ， 如 果 已 经 有 同名 的 数据 库 且 没 有 指定 IF NOT EXISTS， 
则 系统 会 返回 错误 信息 ; create_specification 选项 用 于 指定 数据 库 的 特性 ; CHARACTER 
SET 子 句 用 于 指定 默认 的 数据 库 字 符 集 ; COLLATE 子 句 用 于 指定 默认 的 数据 库 整 理 次 序 。 
例如 ， 有 以 下 命令 语句 : 

mysql> create DATABASE student; 

该 语句 的 功能 是 创建 一 个 名 为 student 的 数据 库 。 输 入 语句 后 按 Enter 键 , 将 在 屏幕 上 输出 : 

Query OK，1 row affected(0.11 sec) 

说 明 语句 执行 成 功 ， 一 个 名 为 student 的 数据 库 已 成 功 创建 。 
< 全 注意 : 语句 后 面 的 分 号 (;) 一 定 不 要 掉 了 ， 它 表示 一 个 完整 的 命令 语句 的 结束 。 

2. 表 的 创建 

使 用 CREATE TABLE 语句 可 以 在 数据 库 中 创建 新 表 ， 其 语法 格式 如 下 : 

CREATE [TEMPORARY]TABLE [IF NOT EXISTS]tbl_ name 

(column definition, ... ) 

[CHARACTER SET charset_name] 

[COLLATE collation name] 

[COMMENT 'string'] 

CREATE TABLE 用 于 创建 带 有 给 定名 称 的 表 ， 由 tbl_name 指定 新 建 表 的 名 称 。 默 认 
情况 下 ， 表 被 创建 到 当前 的 数据 库 中 。 如 果 没 有 当前 数据 库 或 者 数据 库 不 存在 ， 则 会 出 现 
错误 。 为 避免 不 必要 的 麻烦 ， 可 用 类 似 于 db_ name.tbl_ name 的 命名 形式 来 定义 表 的 名 称 ， 
表示 在 特定 的 数据 库 中 创建 表 ， 这 样 就 可 以 不 考虑 当前 数据 库 是 哪 一 个 数据 库 了 。 创 建 表 
格 时 ， 用 户 可 以 使 用 TEMPORARY 关键 词 来 创建 临时 表 。 如 果 表 已 存在 ， 则 使 用 关键 词 
IF NOT EXISTS 以 防止 发 生 错误 。COMMENT 子 句 给 出 列 或 表 的 注释 ，CHARACTER SET 
子 句 用 于 指定 默认 的 数据 库 字 符 集 。 例 如 : 


mysql> use student; 
mysql> create table stu_person(name char(10),sex char(2),age tinyint(2)); 


第 1 行 语句 的 作用 是 选择 当前 数据 库 ， 即 选择 将 新 建 的 表 存 放 到 哪个 数据 库 中 ; 第 2 行 语 
句 的 功能 是 新 建 一 个 名 为 stu_person 的 数据 表 , 共有 3 个 字段 ， 分 别 是 name、sex 和 age 字段 。 


3. SHOW 查看 信息 语句 
SHOW 有 多 种 形式 , 可 以 查看 数据 库 、 表 、 列 或 服务 器 状态 的 信息 。 常 用 的 有 以 下 形式 : 
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SHOW [FULL] COLUMNS FROM tbl name [FROM db name| [LIKE 'pattermn'] 

SHOW DATABASES [LIKE 'pattermn'] 

SHOW [FULL] TABLES [FROM db name] [LIKE 'pattern'] 

SHOW TRIGGERS 

其 中 ， 第 一 条 语句 的 功能 是 显示 一 个 给 定 表 中 各 列 的 详细 信息 ; 第 二 条 语句 的 功能 是 
在 MySQL 服务 器 主机 上 列 出 所 有 数据 库 名 称 及 相关 信息 ; 第 3 条 语句 的 功能 是 查看 用 户 
指定 数据 库 中 的 非 TEMPORARY 表 ; 第 4 条 语句 的 功能 是 显示 目前 在 MySQL 服务 器 已 定 
义 了 的 触发 器 程序 。 


4. 表 的 修改 


使 用 ALTER TABLE 语句 可 以 对 数据 库 中 现 有 的 表 进行 修改 ， 语 法 格式 如 下 : 

ALTER [IGNORE] TABLE tbl name 

alter_specification [, alter_specification] ... 

alter_specification: 

ADD [COLUMN | column definition [FIRST | AFTER col name | 

| ADD [COLUMN] (column definition , ...) 

| ALTER [COLUMN] col name {SET DEFAULT literal | DROP DEFAULT} 

| CHANGE [COLUMN] old_col name column definition [FIRSTIAFTER col name] 

| MODIFY [COLUMN] column definition [FIRST | AFTER col name] 

| DROP [COLUMN] col name 

| DROP PRIMARY KEY | RENAME [TO] new_tbl name 

ALTER TABLE 命令 可 以 修改 表 中 列 的 属性 、 表 的 名 称 ， 还 可 以 增加 或 删除 列 ， 创 建 
或 取消 索引 等 。 其 中 , tbl name 是 被 修改 表 的 名 称 ; IGNORE 关键 字 是 MySQL 在 标准 SQL 
基础 上 做 的 功能 扩展 ， 如 果 指定 了 IGNORE 关键 字 ， 则 对 于 有 重复 关键 字 的 行 ， 只 使 用 第 一 
行 ， 其 他 行将 被 屏蔽 。alter_specification 子 句 用 来 指定 如 何 对 数据 字段 进行 修改 ， 内 容 非常 丰 
富 。 如 果 在 修改 的 过 程 中 出 现 了 错误 值 ， 系 统 会 进行 修正 以 尽量 接近 正确 的 值 。 在 该 子 句 下 
面包 含 了 多 行 代码 , 读者 可 查看 相关 参考 书 或 上 网 对 其 中 各 选项 的 内 容 进 行 详细 了 解 。 例 如 : 

mysql> ALTER TABLE t2 DROP COLUMN c, DROP COLUMN d; 

以 上 语句 的 功能 是 修改 表 t 世 的 表 结 构 ， 将 字段 < 和 d 删除 。 

5. 表 的 删除 


使 用 DROP TABLE 语句 可 以 删除 当前 数据 库 中 的 某 个 表 ， 语 法 格式 如 下 : 

DROP [TEMPORARY] TABLE [IF EXISTS] tbl name [ , tbl name] ... 

该 语句 将 删除 一 个 或 多 个 表 ， 执 行 完 毕 后 ， 所 有 的 表 数 据 和 表 定 义 都 将 被 删除 ， 所 以 
要 慎 用 本 语句 。 为 避免 用 户 错误 地 去 删除 根本 不 存在 的 表 ， 可 以 用 正 EXISTS 语句 来 排除 
这 种 意外 ， 另 外 ， 还 可 用 TEMPORARY 关键 字 来 指定 系统 执行 DROP TABLE 语句 时 只 能 
删除 临时 表 。 
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6. SELCET 查询 语句 


SELCET 查询 语句 的 语法 格式 如 下 : 

SELECT select_expr, ... 

[INTO OUTFILE ‘file name' export_options | INTO DUMPFILE 'file name'] 

[FROM table references | 

[ WHERE where_definition | 

[GROUP BY {col name | expr | position} [ASC | DESC], ...] 

[HAVING where_definition ] 

[ORDER BY {col name | expr | position} [ASC|DESC] ,…] 

[LIMIT {[offset , ] row_count | row_count OFFSET offset} ] 

上 面 整个 SELECT 语句 的 含义 是 : 根据 WHERE 子 句 的 条 件 表达 式 ， 从 FROM 子 名 


指定 的 基本 表 中 找 出 满足 条 件 的 数据 记录 ， 再 按 SELECT 子 句 中 的 目标 列表 达 式 ， 选 出 数 
据 记 录 中 的 属性 值 形成 结果 表 。 如 果 有 GROUP BY 子 句 ， 则 将 结果 按 GROUP BY 子 句 提 
供 的 条 件 进 行 分 组 。 如 果 GROUP BY 子 句 带 有 HAVING 短语 ， 则 只 有 满足 指定 条 件 的 组 
才 被 输出 。 如 果 有 ORDER 子 句 ， 则 结果 表 还 要 按 col name 列 的 值 进行 升序 (ASC) 或 降 
序 (DESC) 排序 。LIMIT 子 句 用 于 给 定 一 个 限 值 ， 限 制 可 被 查询 到 的 记录 数目 。 如 果 要 检 
索 所 有 行 和 列 ， 在 SELECT 子 句 中 使 用 星 号 (*) 来 表示 所 有 列 即 可 ， 并 通过 FROM 子 句 
指定 要 检索 的 表 。 如 有 以 下 语句 : 


瑟 


142 


SELECT * FROM student ORDER BY ST_ID DESC 
以 上 语句 的 功能 是 在 student 表 中 查找 所 有 记录 , 并 且 将 查询 结果 按 ST_ID 降序 排列 显示 。 
7. 删除 记录 
删除 数据 表 中 的 记录 应 使 用 DELETE 语句 ， 该 语句 有 两 种 语法 格式 ， 分 别 介绍 如 下 。 
口 单 表 语法 
DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl name [WHERE where_ 
definition] [ORDER BY ...] [LIMIT row_count] 
口 多 表 语 法 
DELETE [LOW_ PRIORITY] [QUICK] [IGNORE] tbl name[.*] [, tbl name[.*] ...] 
FROM table_references [WHERE where_definition] 
或 
DELETE [LOW PRIORITY] [QUICK] [IGNORE] FROM tbl name[.*] [, tbl name 
[:*] ...] USING table references [WHERE where_definition] 
该 语句 将 从 表 tbl_ name 中 删除 那些 满足 where_definition 所 定义 条 件 的 所 有 记录 , 并 返 


被 删除 记录 的 数目 。 


8. 修改 记录 
修改 数据 表 中 的 记录 应 使 用 UPDATE 语句 ， 该 语句 有 两 种 语法 格式 ， 分 别 介绍 如 下 。 
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口 单 表 语法 

UPDATE [LOW PRIORITY] [IGNORE] tbl name SET col namel=exprl [，col 
name2=expr?2 ...] [WHERE where _ definition] [ORDER BY ...] [LIMIT row_count] 

口 多 表 语 法 

UPDATE [LOW PRIORITY] [IGNORE] table references SET col namel=exprl 

[; col name2=expr2 ...|] [WHERE where_definition] 

其 功能 是 修改 指定 表 中 满足 WHERE 子 句 条 件 的 元 组 。 其 中 ，SET 子 句 给 出 exprl、 
expr2、 expr3 等 值 用 于 取代 相应 的 属性 列 值 。 如 果 省 略 WHERE 子 句 ， 则 表示 要 修改 表 中 
的 所 有 元 组 。 如 果 给 出 了 ORDER BY 子 句 , 则 在 更 新 记录 时 要 按照 被 指定 的 顺序 进行 更 新 。 
LIMIT 子 句 用 于 指定 一 个 整数 ， 该 整数 表示 要 更 新 行 的 数目 。 如 果 用 户 使 用 
LOW_PRIORITY 关键 词 , 则 表示 MySQL 服务 器 将 优先 处 理 其 他 客户 端 读 取 本 数据 表 的 操 
作 ， 待 其 他 用 户 读 取 完 后 再 继续 执行 UPDATE 操作 。 如 果 用 户 使 用 了 IGNORE 关键 词 ， 
则 在 执行 更 新 过 程 中 将 忽略 所 有 错误 消息 。 例 如 : 

mysql> UPDATE persondata SET age=age+1; 

mysql> UPDATE persondata SET age=age*2, age=age+1; 

其 中 第 一 名 的 功能 是 把 所 有 记录 的 age 年龄) 列 的 值 加 1,， 第 二 名 的 功能 是 对 age (年 
龄 ) 列 加 倍 ， 然 后 再 增加 1。 


9. INSERT 插入 语句 


INSERT 用 于 向 一 个 数据 表 中 插入 一 行 新 的 数据 ， 它 有 两 种 语法 格式 ， 分 别 介绍 如 下 。 

INSERT [LOW _ PRIORITY | DELAYED | HIGH PRIORITY] [IGNORE] [INTO] 
tbl_ name [(col name,...)] VALUES ({expr | DEFAULT},...),(...),... [ ON DUPLICATE KEY 
UPDATE col name=expr, ... | 

或 

INSERT [LOW_PRIORITY | DELAYED | HIGH PRIORITY] [IGNORE] [INTO] 
tbl name SET col name={expr | DEFAULT}, ... [ ON DUPLICATE KEY UPDATE 
col name=expr, ... ] 

INSERT…VALUES 和 INSERT…SET 两 种 形式 的 语句 都 表示 将 明确 指定 的 值 插入 到 数 
据 表 新 行 的 相应 字段 位 置 上 。 例 如 ， 有 以 下 语句 : 

INSERT INTO STUDENT(NAME,ID) VALUES (' 李 四 ", 12) 


该 语句 的 执行 结果 是 将 ID 号 为 12、 名 字 为 李 四 的 学 生 记录 插入 到 STUDENT 表 中 。 


6.5 常用 的 可 视 化 MySQL 数据 库 管理 工具 


如 前 所 述 ， 虽 然 MySQL 相对 其 他 数据 库 管理 系统 来 说 具有 很 多 优点 ， 但 由 于 对 数据 
库 的 各 种 操作 必须 在 命令 提示 符 下 进行 编写 和 执行 ， 具 有 难度 高 、 效 率 较 低 、 容 易 出 错 等 
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浆 端 ， 因 此 ， 很 多 用 户 感觉 MySQL 不 好 管理 。 而 phpMyadmin 和 Navicat MySQL 的 出 现 ， 
有 效 地 缓解 了 这 一 矛盾 。 


6.5.1 phpMyAdmin 的 安装 与 使 用 


phpMyadmin 是 用 PHP 开发 的 一 套 程 序 ， 通 过 浏览 器 来 管理 MySQL 数据 库 。 在 
phpMyadmin 中 运行 程序 时 需要 PHP 解析 器 的 支持 ,所 以 必须 在 其 宿主 机 上 事先 安装 好 PHP 
程序 。phpMyadmin 功能 强大 ， 界 面 较为 友好 ， 其 压缩 包 可 以 从 互联 网 上 下 载 。 下 面 以 从 其 
官方 网 站 http:/www.phpMyadmin net 上 下 载 并 安装 2.8.0 版 的 phpMyadmin 程序 为 例 来 介绍 

(1) 将 phpMyAdmin 压缩 包 解 压 ， 得 到 一 个 类 似 于 phpMyAdmin-xx-xx-xx 的 文件 夹 ， 
为 了 使 用 方便 ， 建 议 将 其 重 命名 为 phpMyAdmin。 

(2) 将 phpMyAdmin 文件 夹 复 制 到 APACHE 主 目录 下 ， 以 方便 直接 在 浏览 器 中 输入 
http://localhost/phpMyAdmin/index.php， 按 Enter 键 即 可 运行 此 程序 。 

(3) 打开 phpMyAdmin/scripts 文件 夹 ， 在 其 中 找到 文件 config.defaultphp， 将 其 重 命 
名 为 config.inc.php， 并 将 其 复制 到 phpMyAdmin 根 日 录 下 ， 然 后 打开 此 文件 找到 “$cfg 
Pe ”选项 ,将 其 值 设 为 MySQL 的 超级 管理 员 密码 ， 如 图 6-20 所 示 。 


1/ MySQL user 
/7 MysQL 


Scfgl" Servers, [$i 
password (enly needed 


1/ with “config" 
auth_type) 
Sefg[ es ][Sil['"only_db'] 总 各 和 1/ IF set to a 
db-nane , 

1/ this db is 
displayed in left frane 


图 6-20 修改 phpMyAdmin 的 配置 文件 


< 注意 : 如 果 超 级 管理 员 的 用 户 名 不 是 root, 则 还 需 将 $cfg['Servers'][$i][user] 一 项 设置 为 
实际 的 超级 管理 员 对 应 的 用 户 名 。 

(4) 修改 完 之 后 ， 重 新 保存 该 文件 ， 然 后 在 浏览 器 中 输入 “http://localhosVphpMyAdmin/ 
index.php” 并 按 Enter 键 ,将 在 浏览 器 窗口 中 弹出 如 图 6-21 所 示 的 phpMyAdmin 的 MySQL 
数据 库 管 理 页 面 。 

在 phpMyAdmin 页 面 中 , 用 户 可 以 创建 数据 库 、 选 择 数据 库 、 查 看 表 信息 和 编辑 数据 ， 
下 面 介绍 具体 的 操作 过 程 。 

(1) 创建 数据 库 

在 如 图 6-21 所 示 的 页 面 中 ， 在 “创建 一 个 新 的 数据 库 ” 文 本 框 中 输入 数据 库 名 称 ， 单 
击 “ 创 建 ”按钮 即 可 新 建 一 个 数据 库 。 

(2) 选择 数据 库 

在 如 图 6-21 所 示 的 页 面 中 ， 单 击 其 左 侧 的 “数据 库 ” 下 拉 菜 单 ， 即 可 从 弹出 的 菜单 选 
项 中 选择 数据 库 ， 在 其 右 侧 将 列 出 所 选中 的 数据 库 中 表 的 信息 ， 如 图 6-22 所 示 。 


144 


第 6 章 MySQL 数据 库 的 安装 与 使 用 


indews Internet ERA 


es so 
b Breteonl wei 10 Fe ye 
园 Bs leabort vis TP/TF 
» 用 户 ，rontalecslhest 


国生 各 让 me eevee 4/ mi. [GO 了 


DO we ia ste xx 
rm | 


本 他 一 十 者 的 数 大 库 加 Pp [Cheneeloe] [CVs] [Lists] 
danyangec (29) 


information_schema (16) 区 一 一 一 
El 

车 显示 meat 的 运行 信息 

园 显示 weqt 的 系统 丈量 加 

驹 呈 示 至 回 

加 mee 

storaae Eneines 

WD a wr ® 


人 on 


CT me 


De [ees /ochest sie 


文件 如 蝙 惕 上) 查看 WW 收 席 天 (工具 I) 帮助 0 


ee chinese_ ci 
12_ chinese_ si 
hel2_chinese_ ei 


训 打 m 现 天 数字 


『 铀 丰 提 认 er 中 健一 个 新 
到 到 


(3) 选择 并 浏览 表 信息 
单 击 左 侧 的 表 名 ， 右 侧 将 显示 此 表 的 详细 字段 信息 ， 如 图 6-23 所 示 。 
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图 6-23 在 phpMyAdmin 页 面 中 浏览 数据 表 信息 
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(4) 浏览 及 编辑 数据 
在 页 面 上 方 的 菜单 栏 中 单 击 圈 浏览 按钮 ， 可 打开 该 表 的 记录 进行 浏览 。 在 此 视图 中 可 
以 对 各 条 记录 进行 各 种 编辑 操作 ， 如 图 6-24 所 示 。 


GO es mr 
| 文件 加 纺 六 如 ”查看 妇 收藏 天 办 了 具 D 帮助 如 
RR Blocahst / Locabost /daragee { eyeps, 
<“ 并 在 [00 个 单元 格 后 重 
复 标 是 
8 | 主键 排序 : 大 3 WH 
“T+ catid catnane title keywords description pa 


1 六 记 房产 房产 


EE 


EE 物 S9 各 物品 交易 ”物品 交易 


有 


TT Bae 
图 6-24 在 phpMyAdmin 页 面 中 浏览 和 编辑 表 记 录 


虽然 phpMyAdmin 比 单纯 地 依靠 命令 提示 符 操 作 数 据 库 要 方便 得 多 ， 但 对 于 习惯 用 
Microsoft SQL Server 企业 管理 器 的 用 户 来 说 ， 总 感觉 还 是 不 够 简单 易 用 。 下 面 就 介绍 一 种 
类 似 于 Microsoft SQL Server 的 企业 管理 器 的 Navicat MySQL 桌面 软件 。 


6.5.2 Navicat MySQL 的 安装 与 使 用 


Navicat MySQL 是 一 套 强大 的 MySQL 数据 库 服务 器 管理 及 开发 工具 。 它 支持 3.21 以 
上 版 本 的 MySQL， 并 支持 最 新 版 MySQL 的 大 部 分 功能 ， 包 括 触 发 器 、 存 储 过 程 、 函 数 、 
事件 、 视 图 、 导 入 数据 、 导 出 数据 、 报 表 、 数 据 备 份 与 恢复 以 及 用 户 权 限 管 理 等 。 它 不 仅 
适合 熟练 的 专业 开发 人 员 使 用 ， 新 手 也 很 容易 上 手 。 通 过 图 形 用 户 接口 (GUI) 界面， 用 
户 可 以 像 使 用 Microsoft SQL Server 企业 管理 器 那样 直观 、 便 捷 地 管理 MySQL 数据 库 。 用 
户 可 通过 互联 网 搜索 下 载 Navicat MySQL 软件 (有 的 需要 付费 ， 有 的 是 免费 的 ， 读 者 要 注 
意 选 择 ) ， 也 可 以 从 其 官方 网 站 http://www.navicat.com 中 下 载 。 

Navicat MySQL 软件 安装 成 功 后， 启动 该 软件 ， 首 先 要 做 的 是 新 建 一 个 “连接 ”以 连 
接 到 目标 服务 器 上 。 选 择 “文件 ”菜单 下 的 “创建 连接 ”命令 ， 弹 出 如 图 6-25 所 示 的 对 话 
框 ， 要 求 用 户 定义 连接 名 ， 并 填写 MySQL 服务 器 的 主机 名 或 PP 地 址 、 端 口号 (MySQL 
默认 服务 端口 号 是 3306) 、 用 户 名 和 密码 。 全 部 填写 完毕 后 ， 单 击 “ 连 接 测试 ”按钮 进行 
测试 ， 测 试 成 功 后 再 单 击 “ 确 定 ” 按 钮 ， 此 时 就 新 建 了 一 个 连接 。 

新 建 连接 成 功 后 ， 单 击 该 软件 主 窗口 左 侧 的 连接 名 称 图 标 ,将 展开 如 图 6-26 所 示 的 树 
形 目录 ， 该 目录 显示 了 所 连接 服务 器 上 所 有 的 数据 库 以 及 数据 库 中 所 包含 的 全 部 数据 表 。 

通过 Navicat MySQL 软件 ， 同 样 可 以 对 数据 库 进 行 各 种 操作 ， 包 括 新 建 数据 库 、 新 建 
表 、 修 改 表 、 建 立 视 图 和 新 建 存储 过 程 等 , 其 操作 过 程 都 是 可 视 化 的 , 与 Microsoft SQL Server 
企业 管理 器 的 使 用 方法 非常 类 似 。 由 于 篇 幅 有 限 ， 这 里 不 再 详 述 。 
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ED 
|i | ss |sa | ume | 
这 于 各 [ 刘 吕 加 | 量 加 部 已 局 名 
于 ET 
二 上 他 让: ==- DER 了 了 BR eR SR JA ”| 
四 [| Ee " 
用 记名 | 
2 [| 
所 保存 窑 码 
ed EEC 
图 6-25 在 Navicat MySQL 中 新 建 连接 图 6-26 ”Navicat MySQL 的 管理 界面 


6.6 案例 剖析 : 学 生成 绩 数据 库 规 划 与 实现 


信息 流 用 来 描述 现实 世界 中 一 些 事物 某 些 方面 的 特征 及 事物 间 的 相互 联系 。 数 据 库 是 模 
拟 现实 世界 中 信息 流 的 集合 ， 数 据 库 中 所 存储 的 数据 是 对 现实 世界 中 信息 流 的 数据 化 。 下 面 
以 创建 一 个 学 生成 绩 数据 库 为 例 简单 介绍 在 MySQL 中 实现 数据 库 项 目的 过 程 。 


6.6.1 程序 功能 介绍 


学 生成 绩 数据 库 〈cjdatabase) 主要 用 于 存储 每 个 学 生 每 门 课 程 的 考试 成 绩 。 在 设计 该 
数据 库 时 ， 要 考虑 到 在 储存 成 绩 数据 过 程 中 数据 的 完整 性 和 一 致 性 等 数据 库 规 范 问 题 。 下 
面 简单 介绍 一 下 具体 的 实施 方案 。 

简单 地 说 ， 为 实现 该 数据 库 功 能 ， 可 在 学 生成 绩 数据 库 中 设计 3 个 数据 库 表 ， 存 储 学 
生 记 录 的 student 表 、 存 储 课程 数据 的 coursetb 表 和 存储 成 绩 的 scores 表 , 其 结构 如 表 6-5 一 
表 6-7 所 示 。 


表 6-5 student 表 的 结构 


允许 为 空 值 (NULL) 
耕 


课程 号 (主键 ) 
课程 名 称 


varchar 30 
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续 表 


允许 为 空 值 (NULL) 


字 段 名 数据 类 型 允许 为 空 值 (NULL) 
学 号 char 否 
课程 号 char 否 
成 绩 tinyint 是 
流水 号 〈 主 键 ) bigint 否 
备注 Varchar 是 


6.6.2 程序 代码 分 析 


基于 前 面 对 数 据 库 功 能 的 分 析 和 描述 ， 编 写 如 下 SQL 程序 代码 。 
口 新建 数据 库 cjdatabase 代码 

CREATE DATABASE cjdatabase DEFAULT CHARSET=gb2312; 

口 ” 新 建 表 student 的 代码 


CREATE TABLE student ( 

学 号 char(2)NOT NULL default "， 

姓名 char(10)default NULL, 

班级 编号 char(10)default NULL， 

性 别 char(2)default NULL, 

出 生年 月 date default NULL, 

PRIMARY KEY( 学 号 ) 

) ENGINE=InnoDB DEFAULT CHARSET=gb2312; 


口 新建 表 coursetb 的 代码 


CREATE TABLE coursetb ( 

课程 号 char(8)NOT NULL default "， 

课程 名 称 varchar(30)default NULL, 

学 分 tinyint(4)default NULL, 

课时 数 tinyint(4)default NULL, 

PRIMARY KEY( 课 程 号 ) 

) ENGINE=InnoDB DEFAULT CHARSET=gb2312; 


口 新建 表 scores 的 代码 
CREATE TABLE scores ( 
课程 号 char(255)NOT NULL, 
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学 号 char(255)NOT NULL， 

成 绩 int(11)default NULL， 

流水 号 bigint(10)NOT NULL auto_increment, 

备注 varchar(50)default NULL， 

PRIMARY KEY( 流 水 号 ) 

) ENGINE=InnoDB DEFAULT CHARSET=gb2312; 


6.7 本 章 小 结 


本 章 着 重 介绍 了 MySQL 数据 库 的 安装 与 配置 , 同时 在 讲解 如 何 操作 MySQL 的 过 程 中 ， 
详细 讲述 了 SQL 语句 在 MySQL 中 的 具体 用 法 ， 最 后 介绍 了 两 种 目前 比较 流行 的 MySQL 数 


据 库 管理 工具 : phpMyAdmin 和 Navicat MySQL 。 
6.8 练 习 题 


简 述 MySQL 支持 的 数据 类 型 。 
MySQL 有 哪些 特点 与 优点 ? 


上 mm PP 一 
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如 何 列 出 当前 MySQL 服务 器 中 的 所 有 数据 库 ? 如 何 删除 一 个 数据 库 ? 
使 用 SELECT 查询 语句 查询 数据 记录 时 ， 如 何 设置 要 返回 的 记录 数 ? 


在 MySQL 中 创建 一 个 学 生 选 课 数 据 库 (SeleCourseDB) ， 其 中 包含 5 个 表 : 教师 表 
Teacher、 学 生 表 Student、 课 程 表 Course、 选 课表 SeleCourse 和 授课 表 TeachCourse， 各 表 


的 结构 如 表 6-8 一 表 6-12 所 示 。 
表 6-8 教师 表 Teacher 


字 段 名 数据 类 型 长 度 允许 为 空 值 NULL) 
教师 号 (主键 ) char 10 否 
教师 姓名 char 8 否 
性 别 char 入 否 
年 龄 tinyint 3 否 
职称 char 10 否 
工资 tinyint 是 
岗位 津贴 tinyint 5 是 
系 名 char 10 否 
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表 6-9 学 生 表 Student 


字 段 名 允许 为 空 值 (NULL) 
学 号 (主键 ) 四 
学 生 姓名 雷 
性 别 否 
年 龄 村 
系 名 是 
字 段 名 允许 为 空 值 (NULL) 
课程 号 (主键 ) 
课程 名 下 
课时 数 是 
表 6-11 选课 表 SeleCourse 
(NULL) 


(NULL) 


教师 号 (主键 ) 
课程 号 


1S0 
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知识 点 : 


修改 PHP 配置 文件 以 开启 与 MySQL 相关 的 函数 库 
连接 MySQL 数据 库 

选择 与 操作 MySQL 中 的 数据 库 

如 何 获取 MySQL 中 的 数据 集 

常用 的 MySQL 函数 的 使 用 方法 


本 章 导读 : 


PHP 是 一 种 Web 编程 语言 ，MySQL 是 一 款 网 络 数据 库 ， 从 PHP 诞生 起 ， 就 一 直 将 
MySQL 数据 库 作 为 其 默认 支持 的 数据 库 管理 系统 ,目前 这 二 者 已 成 为 业界 公认 的 开发 Web 
项 目的 黄金 组 合 。 为 了 让 用 户 能 方便 地 在 PHP 程序 中 使 用 MySQL 数据库，PHP 提供 了 一 
组 MySQL 库 函 数 ， 用 于 实现 对 MySQL 数据 库 的 访问 ， 本 章 以 如 何在 PHP 程序 中 操作 
MySQL 数据 库 为 例 进行 详细 讲解 。 


回回 罗网 加 


7.1 运用 PHP 和 MySQL 联合 开发 Web 的 优势 


与 其 他 开发 Web 应 用 程序 的 组 合 相 比 , PHP 与 MySQL 的 组 合 更 加 安全 , 运行 速度 更 快 。 
MySQL 数据 库 是 一 个 快速 、 健 壮 、 多 用 户 的 SQL 数据 库 服务 器 ， 它 支持 多 线程 、 关 键 任 
务 以 及 重负 载 生产 系统 的 使 用 ， 可 以 将 它 撕 入 到 一 个 大 型 的 软件 中 去 。 除 此 之 外 ， 二 者 都 
为 免费 资源 ， 且 都 简单 易 用 ， 安 全 效率 比 ASP+MSSQL 等 开发 组 合 要 好 很 多 。 

和 PHP 一 样 ，MySQL 的 入 门 门槛 也 较 低 ， 绝 大 多 数学 了 标准 SQL 语句 的 程序 员 都 很 
容易 转型 为 MySQL 程序 员 。 基 于 以 上 得 天 独 厚 的 特点 , 使 用 以 PHP 为 核心 的 PHP+MySQL 
+Apache 经 典 组 合 来 开发 Web 应 用 ， 将 大 大 提高 程序 员 的 工作 效率 ， 且 花费 也 较 少 。 


7.2 连接 MySQL 数据库 的 前 期 准备 工作 


要 使 PHP 程序 能 方便 地 管理 MySQL 数据 库 ， 必 须 保证 在 PHP 程序 中 正确 连接 上 了 
MySQL 数据 库 ， 在 此 前 提 下 才能 对 其 中 的 数据 库 进 行 各 种 操作 。PHP 对 MySQL 数据 库 的 
操作 大 部 分 是 通过 MySQL 函数 来 进行 的 ， 所 以 首先 要 开启 MySQL 函数 库 。 

用 记事 本 打开 php.ini 文件 ， 找 到 “:extension=php_mysqldll”， 将 此 行 前 面 的 分 号 去 
掉 ， 如 图 7-1 所 示 ， 然 后 保存 此 文件 并 重新 启动 Apache， 为 验证 MySQL 函数 是 否 已 被 载 


了 PHP Web 开发 实用 教程 


入 ， 可 通过 在 PHP 程序 中 调用 phpinfo0 函 数 来 查看 ， 运 行 PHP 程序 后 ， 如 果 在 返回 的 页 
面 中 有 MySQL 的 项 目 ， 这 说 明 已 经 正确 载 入 了 MySQL 数据 库 ， 如 图 7-2 所 示 。 


Php -91 

=php_pgsql -d11 

=php_shnop .d11 
Al 


ie sockets.dl1 
Sextension=php_sqlite. dL 


图 7-1 修改 PHP 配置 文件 图 7-2 查看 是 否 开启 MySQL 数据 库 
7.3 PHP 操作 MySQL 数据 库 常用 方法 


PHP 提供 了 一 组 MySQL 库 函 数 ， 用 于 实现 对 MySQL 数据 库 的 访问 ， 具 体 过 程 是 : 
PHP 程序 连通 MySQL 数据 库 后 , 通过 在 前 台 PHP 页 面 中 柑 入 要 执行 的 SQL 语句 ,然后 将 
SQL 语句 发 送 给 MySQL 数据 库 服务 器 ， 由 MySQL 数据 库 服 务 器 执行 这 些 指 令 ， 然 后 将 
结果 返回 到 PHP 程序 中 并 转换 为 HTML 形式 传 回 给 客户 端 用 户 。 


7.3.1 连接 数据 库 


连接 数据 库 是 操作 MySQL 数据 库 的 第 一 步 ， 也 就 是 建立 一 条 PHP 程序 到 MySQL 数 
据 库 之 间 的 通道 ， PHP 向 MySQL 数据 库 服务 器 发 送 的 各 种 SQL 指令 都 是 基于 这 条 连接 的 
通道 。 在 PHP 中 ，MySql_connectO 函 数 就 是 用 来 建立 和 MySQL 数据 库 的 连接 ， 其 语法 格 
式 如 下 : 

resource MySql] connect([string server [, string usermame [, string password [, bool new_link 
[L int client flags]]]]]) 

MySql_connect0 函 数 的 功能 是 建立 一 个 到 MySQL 服务 器 的 连接 ， 如 果 成 功 则 返回 一 
个 MySQL 连接 标识 ， 失 败 则 返回 FALSE。 其 中 server 参数 用 于 指定 要 连接 的 MySQL 服 
务 器 ， 可 以 包括 端口 号 ， 如 'localhost:3306'; 参数 username 和 password 分 别 用 于 指定 用 户 
账号 和 密码 ;，new_link 指定 是 否 要 建立 新 的 连接 ， 如 果 不 指定 该 参数 ， 则 用 同样 的 参数 第 
二 次 调用 MySql_connectO 函 数 时 将 不 会 建立 新 的 连接 ， 而 是 返回 已 经 打开 的 第 一 次 建立 连 
接 的 连接 标识 。 

MYySql connectO 函 数 共 有 5 个 参数 ， 但 通常 情况 下 只 需 前 3 个 参数 即 可 ， 例 如 : 
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<?php 

Slink = MySql_connect("localhost", "user_name", "user_password ) 
or die(" 连 接 数据 库 失 败 “". MySql_error()); 

echo “<p> 数 据 库 连接 成 功 ! </p>\n”; 


3 


在 实际 应 用 中 如 果 没 有 提供 可 选 参数 ， 则 系统 采用 默认 值 即 server = 'localhost:3306'， 
username = 服务 器 进程 所 有 者 的 用 户 名 ，password = 空 密码 。 


7.3.2 选择 数据 库 


通过 MySql_connectO 函 数 连接 到 MySQL 服务 器 后 ， 可 以 使 用 MySql_select_db() 函 数 
从 MySQL 中 选择 所 要 操作 的 数据 库 ， 其 语法 格式 如 下 : 

bool MySql_select db(string database_ name, int [link identifier]); 

其 中 ， 参 数 database name 指定 数据 库 名 称 ; link identifier 指定 由 MySql_connect() 函 
数 返 回 的 连接 标识 ， 如 果 没 有 指定 该 参数 ， 则 表示 使 用 上 一 个 打开 的 连接 ， 如 果 找 不 到 上 

-个 打开 的 连接 ， 则 无 参数 调用 MySql_connect0 函 数 ， 以 尝试 打开 一 个 连接 ， 连 接 成 功 就 

直接 使 用 该 连接 。MySql_select_db0 函 数 返 回 一 个 布尔 型 的 值 ， 如 果 执 行 成 功 返 回 TRUE， 
否则 返回 FALSE。 例 如 : 


<?php 
Sid = MySql_connect("localhost", "MySql_user", "MySql_password"); 
Sok=MySql_select_db("cjdatabase", $id); 
If($ok) 
echo "<p> 数 据 库 选 择 成 功 ! </p>\n"; 


else 


echo "<p> 选 择 数据 库 失败 ! 请 确定 数据 库 是 否 存在 。</p>\n"; 


7.3.3 ”对 数据 库 进行 操作 


连接 到 数据 库 服务 器 ， 并 选择 了 要 操作 的 数据 库 后 ， 下 一 步 就 是 向 服务 器 发 送 操作 指 
令 ,， 也 就 是 第 6 章 中 讲 到 的 各 种 SQL 语句 。 要 使 SQL 指令 能 传送 到 MySQL 服务 器 中 ， 需 
使 用 MySql _query0 函 数 ， 其 语法 格式 如 下 : 

resource MySql] query( string $query [, resource $link identifier ] ) 

MySql_query0 向 与 指定 的 连接 标识 符 link_identifier 所 关联 服务 器 中 的 当前 活动 数据 库 
发 送 一 条 内 容 为 query 的 查询 。 如 果 没 有 指定 link identifier 连接 标识 ， 则 使 用 上 一 个 打开 
的 连接 ; 如 果 没 有 可 使 用 的 连接 , 则 无 参数 调用 MySql_connect0 函 数 以 尝试 建立 一 个 连接 ， 
然后 使 用 该 连接 。 该 函数 的 使 用 十 分 简单 ， 只 需 将 一 条 SQL 语句 作为 参数 传递 给 服务 器 即 
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可 ， 然 后 由 服务 器 执行 该 SQL 语句 ， 其 查询 结果 将 会 被 缓存 。 例 如 : 


<?php 
$id = MySql_connect("localhost", "MySql_user", "MySql_password"); 
$ok=MySql_select_ db("cjdatabase", $id); 
If($ok) 
{ 
Sresult = MySql_query('SELECT * from student'); 
if (I$result) 


Die(' 无 效 查 询 ' . MySql_error()); 
} 
else 
echo "成 功 执行 SQL 语句 "; 
} 


?> 


正如 前 述 ，MySql_query0 函 数 可 以 向 服务 器 发 送 任何 合法 的 SQL 指令 ， 例 如 : 


<?php 
Sid=MySql_connect("localhost","root","ld1224"); 
MySql_select_db("bbs_data", $id); 
MySql_query("SET CHARACTER SET gb2312"); 
for($i=1;$i<6; $i++){ 
$pw="pw'".$i; 
S$xm="name". $i; 
$sql="INSERT INTO users(user_name,user_pw) VALUES(".$xm.",".$pw.")"; 
$excu=MySql_query($sql,$id); 
If($excuj{ 
echo $sql; 
echo "第 ".$i." 条 数据 插入 成 功 ! <br>"; 
}else{ 
echo "数据 插入 失败 ， 错 误 信息 : <br>"; 
echo MySql_error(); 


} 
MySql_close($id); 
?> 


上 述 程 序 是 利用 一 个 for 循环 向 服务 器 发 送 了 多 条 insert 指令 , 向 bbs_data 数据 库 中 的 
users 表 插 入 了 多 条 记录 , 可 以 使 用 第 6 章 讲 到 的 可 视 化 管理 工具 Navicat MySQL 来 查看 刚 
刚 插入 的 记录 ， 如 图 7-3 所 示 。 也 可 以 在 命令 提示 符 中 登录 数据 库 ， 登 录 成 功 后 ， 先 用 use 
指令 将 users 表 所 在 的 数据 库 打 开 ， 然 后 用 “select * from users” 命 令 来 浏览 表 中 的 所 有 数 
据 ， 如 图 7-4 所 示 ， 最 后 在 程序 结束 前 用 MySql_closeO 函 数 来 关闭 数据 库 连 接 。 
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-5 
文件 人 编 避 人 E) 查看 如) 窗口 介 


习 导 入 向 导 D 本 导出 向 导 ) :第 检 向 导 | 口 ] 网 格 视 图 司 表单 视图 全 ? 
| 回 [user_name ser pw ~ 
1 namel pwl 
2 namez pw 
3 nome3 pw3 
D namet pw 
Snane5 pw | 
We eo PE 


AT users SET user_pr = pv WEE Cid= 也 录 475 于 页 1 


图 7-3 在 Navicat MySQL 中 查看 users 记录 


mnunity-nt 


ce’ to clear the buffer. 


图 7-4 通过 命令 提示 符 查 看 表 记 录 
7.3.4 其 他 常用 的 MySQL 函数 
前 面 介 绍 了 操作 数据 库 时 常用 到 的 几 个 基础 函数 ， 除 此 之 外 ，PHP 还 提供 了 大 量 的 
MySQL 函数 。 只 有 了 解 了 这 些 函 数 ， 明 确 了 基本 的 操作 步骤 ， 程 序 员 才 能 够 熟练 运用 


PHP+MySQL 组 合 开发 出 功能 强大 的 Web 应 用 程序 。 
PHP 中 用 来 操作 MySQL 数据 库 的 函数 如 表 7-1 所 示 。 


表 7-1 PHP 中 的 MySQL 函数 


函 数 名 功能 描述 
MYySql affected_rows! 取得 上 一 次 MySQL 操作 所 影响 的 记录 行 数 
MySql_change user! 改变 活动 连接 中 登录 的 用 户 
MySql_client encoding() 返回 当前 连接 的 字符 集 的 名 称 
MySql close0 关闭 非 持久 的 MySQL 连接 
MySql_ connectO 打开 非 持 久 的 MySQL 连接 
MySqL_create db 新 建 MySQL 数据 库 ， 其 功能 可 使 用 MySql_query0 替 代 
MySql data_seekt 移动 记录 指针 
MySql db name! 从 对 MySql list dbsO0 的 调用 返回 数据 库 名 称 

发 送 一 条 MySQL 查询 , 其 功能 可 使 用 MySql_ select db0 和 MySql query0 


MySql db_ queryO 代替 
日 


1SS 
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函 数 名 


功能 描述 


续 表 


MySql drop db0) 
MySql ermno0 


于 弃 《 删 除 ) 一 个 MySQL 数据 库 
返回 上 一 个 MySQL 操作 中 的 错误 信息 的 数字 编码 


MySql error0 


返回 上 一 个 MySQL 操作 产生 的 文本 错误 信息 


MYySql_ escape _string 
MySql fetch_aray0O 


转 义 一 个 字符 串 用 于 MySql query 


从 结果 集中 取得 一 行 作为 关联 数组 ， 或 数字 数组 ， 或 二 者 兼 有 


MySql_fetch_assocO 


从 结果 集中 取得 一 行 作为 关联 数组 


MySdql fetch_field 
MySdql _fetch_lengthsO 


从 结果 集中 取得 列 信息 并 作为 对 象 返回 
取得 结果 集中 每 个 字段 内 容 的 长 度 


MySql_fetch_obiectO 


从 结果 集中 取得 一 行 作为 对 象 


MySql fetch row0) 
MySdql field flagsO 


从 结果 集中 取得 一 行 作为 数字 数组 
从 结果 中 取得 和 指定 字段 关联 的 标志 


MySql field_len0 


返回 指定 字段 的 长 度 


Sql field_name! 

Sql field seekO 
Sql_field table 

Sql field type 

Sql free resultO 
Sql get client info 
Sql get host info 
Sql get proto info0) 
Sql get server info0) 
Sql_info 

Sql insert id0) 

Sql list_dbs 

Sql list fields0) 
MySql_list_processesO 


天 辐 辐 辐 辐 辐 国 辐 辐 国 只 


取得 结果 中 指定 字段 的 字段 名 

将 结果 集中 的 指针 设 定 为 指定 的 字段 偏 移 量 
取得 指定 字段 所 在 的 表 名 

取得 结果 集中 指定 字段 的 类 型 
释放 结果 内 存 

取得 MySQL 客户 端 信息 

取得 MySQL 主机 信息 

取得 MySQL 协议 信息 

取得 MySQL 服务 器 信息 

取得 最 近 一 条 查询 的 信息 

取得 上 一 步 INSERT 操作 产生 的 ID 
列 出 MySQL 服务 器 中 所 有 的 数据 库 
列 出 MySQL 结果 中 的 字段 

列 出 MySQL 进程 


MySql list_tablesO 


列 出 MySQL 数据 库 中 的 表 


MySql num fields! 
MySql num rowsO 


取得 结果 集中 字段 的 数目 
取得 结果 集中 行 的 数目 


MySql pconnectO 打开 一 个 到 MySQL 服务 器 的 持久 连接 
MySqlL ping Ping 一 个 服务 器 连接 ， 如 果 没 有 连接 则 重新 连接 
MySql_ query0 发 送 一 条 MySQL 查询 


MySql_ real _escape_stringO 


转 义 SQL 语句 中 使 用 的 字符 串 中 的 特殊 字符 


MySql resultO 
MySql select db0) 


取得 结果 数据 
选择 MySQL 数据 库 


MySql_ statO 


取得 当前 系统 状态 信息 


MYySql tablenameg) 
MySql thread id0) 


取得 表 名 ， 在 后 期 版 本 中 已 被 MySql query0 代 替 
返回 当前 线程 的 人 


MySql unbuffered queryO 
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表 7-1 列 出 的 函数 中 , 最 常用 的 有 MySql_connect(0)、MySql_ select_db()、MySql]_query(0)、 
MySql fetch_ array0、MYySql num rows0 和 MySql close0 等 。 前 3 个 函数 前 面 已 做 了 介绍 ， 
下 面 通过 一 个 例子 来 讲述 其 他 几 个 函数 的 用 法 。 


<?php 
S$constr=MySql_connect("localhost","root","ld1224"); 
MySql_select_db("ygg!l", $constr); 
MySql_query("SET CHARACTER SET gb2312"); 
Squery="SELECT * FROM employees"; 
Sresult=MySql_query($query,$constr); 
echo "<table border=1 width=200 align=center><tr><td> 姓 名 </td><td> 文 化 程度 </td></tr>"; 
$datanum=MySql_num_rows($result); 
echo " 表 employees 中 共有 ".$datanum." 条 数据 <br> ; 
for($i=1;$i<=$datanum;$i++){ 
Sinfo=MySql_fetch_array($result, MYSQL_ASSOC); 
echo "<tr><td>".S$info['Name']."</td>"; 
echo "<td>".$info['Education']."</td></tr>"; 


echo "</table>"; 
MySql_close($constr); 
?> 


s 到 xjkeaes OE 
jl 

表 erployees 中 共有 12 杀 雪 据 

姓名 区 化 程度 


[ET 


图 7-5 从 表 中 读 取 数据 


在 上 例 中 ， 用 MySql_query0 函 数 发 送 了 一 条 SQL 指令 ， 服 务 器 返回 了 所 有 满足 条 件 
的 记录 ， 其 返回 类 型 是 一 个 资源 类 型 ， 其 中 包含 了 若干 条 记录 的 记录 集 ， 但 不 能 直接 输出 ， 
其 结果 和 暂 存 于 $result 中 。 接 着 用 MySql num rows() 函 数 来 统计 记录 集中 记录 的 条 数 ， 并 将 
统计 结果 存放 到 变量 $datanum 中 。 最 后 用 MySql fetch_array0 函 数 将 记录 集中 的 内 容 输 出 
到 <table></table> 标 记 对 中 。MySql fetch_array0 函 数 比 较 常 用 ， 下 面 将 着 重 介 绍 。 

MySql fetch_array0 函 数 的 语法 格式 如 下 : 

array MySql fetch array(resource result [,int result type]) 

该 函数 的 作用 是 : 读 取 记录 集中 的 当前 记录 , 将 记录 的 各 个 字段 值 存 入 到 一 个 数组 中 ， 
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并 返 
则 返 
标 ， 


数据 
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化 程度 一 栏 的 信息 ， 则 用 $info['Education'] 来 获取 。 


口 MySql NUM: 返回 的 数组 以 从 0 开始 的 数字 为 下 标 。 在 本 例 中 ， 由 于 返回 
记录 只 有 两 个 字段 ， 则 可 用 $info[0]、Sinfo[1] 来 分 别 表示 两 个 不 同 的 字段 。 
口 MySql BOTH: 返回 的 数组 既 可 用 字段 名 作为 下 标 ， 也 可 用 数字 作为 下 标 。 


回 这 个 数组 ， 然 后 将 记录 集 指针 移动 到 下 一 条 记录 。 如 果 记 录 集 指针 已 经 处 于 末尾 ， 
回 FALSE。 其 中 ， 参 数 result_type 为 可 选项 ， 用 来 指定 返回 的 数组 采用 什么 形式 的 下 
通常 有 如 下 3 种 选择 。 


口 MySql ASSOC: 返回 的 数组 以 该 记录 的 字段 名 称 作为 下 标 。 如 在 本 例 中 要 输出 文 


的 每 条 


下 面 再 介绍 一 个 例子 , 该 例子 将 根据 MySql_ num rows0 函 数 返 回 的 记录 个 数 自动 地 分 
页 输出 数据 集中 的 所 有 记录 。 本 程序 数据 源 采 用 的 是 在 第 6 章 案例 剖析 中 搭建 的 学 生成 绩 


库 中 的 学 生 表 student， 程 序 代码 如 下 : 
<html> 
<head> 


<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 无 标题 文档 </title> 
</head> 
<body> 
<?php 
S$id=MySql_connect("localhost","root","ld1224"); 
MySql_select_db("pxscj", $id); 
MySql_query("SET CHARACTER SET gb2312"); 
$query="SELECT 学 号 ,姓名 FROM student"; 
Sresult=MySql_query($query, $id); 
$totalnum=MySql_num_rows($result); 
$pagesize=15; 
$page=$_GET["page'"]; 
If($page==""){ 
Spage=1; 
} 
Sbegin=($page-1) * $pagesize; 
Stotalpage=ceil($totalnum/$pagesize); 
echo "<table border=1 width=50% align=center><tr><td> 姓 名 </td><td> 学 号 </td></tr>"; 
$datanum=MySql_num_rows($result); 
echo " 表 中 共有 ".$totalnum." 条 数据 。"; 
echo "每 页 显示 ".$pagesize." 条 ， 共 ".$totalpage." 页 <br>"; 
for($j=1;$j<=$totalpage;$j++\{ 
echo "<a href=untitled.php?page=".$j.">[".$j."]&nbsp;</a>"; 
} 
$query="select 学 号 ,姓名 from student limit $begin,$pagesize"; 
Sresult=MySql_query($query, $id); 
$datanum=MySql_num_rows($result); 
for($i=1;$i<=$datanum; $i++){ 
$stuinfo=MySql_fetch_array($result,MYSQL_ASSOC); 
echo "<tr><td>".$stuinfo[' 姓 名 和]."</td>"; 
echo "<td>".$stuinfo[ 学 号 ]."</td></tr>"; 
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} 

echo "</table>"; 
MySql_close($id); 
?> 

</body> 
</html> 


在 上 述 程序 中 ， 先 利用 ceil0 函 数 计算 出 要 显示 的 页 数 ， 该 函数 的 功能 是 对 参数 进行 取 


整 ; 然后 ， 用 带 limit 参数 的 select 语句 分 别 计算 出 每 页 显示 的 记录 内 容 。 其 运行 结果 如 
图 7-6 所 示 。 


表 中 共有 22 杀 数据 。 每 页 中 示 15 杀 ， 共 2 页 
1] [2] 


这 可 

[Er 
081102 
(081103 
81104 
[sl106 
EI 
[ET 
[EI 
lo81110 
[081111 
(C81113 
[081201 
(081202 


图 7-6 分 页 输出 数据 库 表 中 的 数据 
7.4 案例 剖析 : 网 上 学 生成 绩 查 询 系 统 的 实现 


PHP 与 MySQL 结合 可 以 出 开发 功能 强大 的 Web 应 用 程序 , 且 实 现 的 项 目 可 移植 性 强 ， 
能 无 障碍 地 跨 平台 运行 。 下 面 以 某 大 学 网 上 成 绩 查 询 系统 为 例 来 介绍 如 何 利 用 PHP+MySQL 
开发 应 用 程序 ， 希 望 能 起 到 抛砖引玉 的 作用 。 


7.4.1 程序 功能 介绍 


为 讲述 方便 ， 本 实例 将 使 用 第 6 章 案例 剖析 中 搭建 的 学 生成 绩 数据 库 〈cjdatabase) 作 
为 后 台数 据 库 。 由 于 学 生 在 成 绩 查 询 过 程 中 ， 不 仅 涉及 班级 、 学 号 、 姓 名 等 信息 ， 还 涉及 
课程 名 称 、 每 门 课程 的 学 分 、 课 时 数 、 考 试 分 数 等 信息 。 因 此 ， 可 在 学 生成 绩 数据 库 中 以 
student、coursetb 、scores 作为 基础 建立 视图 ， 视 图 名 称 命名 为 “成 绩 视图 ”， 其 SQL 代码 
如 下 : 

SELECTcoursetb. 课 程 号 ,coursetb. 课 程 名 ,coursetb. 开 课 学 期 ,coursetb. 学 时 ,coursetb. 学 分 ， 


scores. 学 号 ,scores. 课 程 号 ,scores. 成 绩 ,student. 姓 名 ,student. 专 业 FROM coursetb， 
scores, student WHERE coursetb. 课 程 号 =scores. 课 程 号 AND scores. 学 号 =student. 学 号 
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另外 ， 为 了 将 客户 端 用 户 查 询 的 条 件 传递 给 远 端 服务 器 ， 需 在 查询 页 面 中 设置 表单 
以 方便 用 户 设置 查询 条 件 ， 其 代码 如 下 : 


<form id="form1" name="form1" method="post" action="case7.php"> 请 输入 班级 编号 
<input type="text" name="classid" id="classid" /> 
<input name="submit1" type="submit" id="submit1" value=" 提 交 " /> 
<input type="reset" name="btnreset" id="btnreset" value=" 重 置 " /> 

</form> 


其 中 表单 的 名 称 (name) 为 forml1， 处 理 表单 数据 的 方式 (method) 是 post， 表 示 用 
提交 的 方式 将 客户 端的 查询 指令 传递 给 服务 器 。 处 理 表单 数据 的 服务 器 端 脚本 程序 是 
case7.php， 在 本 例 中 就 是 程序 本 身 ， 即 处 理 表单 的 程序 代码 来 自 当 前 文件 中 。 此 处 也 可 以 
写成 action=""， 表 示 处 理 表单 数据 的 脚本 程序 包含 在 当前 程序 中 。 

用 户 在 文本 框 中 输入 班级 编号 ， 然 后 单 击 “提交 ”按钮 ， 即 可 将 查询 的 结果 返回 到 页 
面 中 。 程 序 运 行 效果 如 图 7-7 所 示 。 


plerer 


六 件 四 加 名 区 ) 可 理由 由 戎 亚 他 | 工具 CJ) 帮助 o) 
记忆 鄞 丈 。 乱 成 炳 查 测 系 析 


x x x x XXX 大 学 网 络 成 绩 查 词 系统 
请 输入 3 名 编 号 ms | 


学 号 课 才 | 太 级 编号 开课 学 其 


081102| 种 7 检 力 学 alog611 |200972010 学 年 第 1 学 其 
081102| 钟 2 78|o8611 2009/2010 学 年 第 2 学 其 
L109] lose11 .2009/2010 学 年 第 1 学 其 


70log611 |2009/2010 学 年 第 1 学 其 
1105| 邹 团 $1|08611 200972010 学 年 第 2 学 其 
081104| 表 国电 上 lo8611 2009/2010 学 年 第 1 学 期 


081104| 训 国史 上 os6ll 200972010 学 年 第 1 学 期 
081104| 宫 国 害 “| 离散 数 [os511 |2009/2010 学 年 第 2 学 其 
081106| 邓 充 hl 5|os611 |2009/2010 学 年 第 1 学 其 
osi106| 于 亮 ”二 lL "1los611 2009/2010 学 年 第 1 学 期 


目 国 罗 图 贺 国 国 国 四 四 旺 天 
固 目 同 国 肯 


7.4.2 程序 代码 分 析 


基于 上 述 对 网 上 学 生成 绩 查 询 系统 的 功能 分 析 和 描述 ， 编 写 了 如 下 程序 代码 : 


<html> 

<head> 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

<title> 成 绩 查 询 系统 </title> 

</head> 

<body> 

<p align="center" class="STYLE2"> X XXX XXX 大 学 网 络 成 绩 查询 系统 

<form id="form1" name="form1" method="post" action="case7.php"> 请 输入 班级 编号 
<input type="text" name="classid" id="classid" /> 
<input name="submit1" type="submit" id="submit1" value=" 提 交 " /> 
<input type="reset" name="btnreset" id="btnreset" value=" 重 置 " /> 
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</form></p> 
<?php 
If(isset($_POST["submit1"])) 
{ 
If(empty($_POST['classid"])) 
d 
echo "<p align=center> 班 级 编号 不 能 为 空 ! </p>"; 
die(); 
) 
else 
{ 


$id=MySql_connect("localhost","root","ld1224"); 
MySql_select_db("cjdatabase", $id); 
MySql_query("SET CHARACTER SET gb2312"); 
$zy=(string)$_POST[classid]; 
$query="SELECT 学 号 ,姓名 ,课程 名 ,成 绩 ,班级 编号 ,开课 学 期 ,学 时 ,学 分 ,课程 号 FROM 
成 绩 视图 where 班级 编号 like '$zy%"; 
$result=MySql_query($query,$id); 
$totalnum=MySql_num_rows($result); 
echo "<table border=1 width=85% align=center border=1 cellspacing=0 
bordercolorlight= #000080 bordercolordark=#FFFFFF><tr><td > 学 号 </td><td width=10%> 姓 名 
</td><td width=20%> 课程 名 </td><td> 成 绩 </td><td width=20%> 班 级 编号 </td><td width=30%> 开 
课 学 期 </td><td> 学 时 </td><td> 学 分 </td><td> 课 程 号 </td></tr>"; 
for($i=1;$i<=$totalnum;$i++) 
{ 
Sinfo=MySql_fetch_array($result, MYSQL_ASSOC); 
echo "<tr><td>".$info[" 学 号 "]."</td>"; 
echo "<td>".$info[" 姓 名 "]."</td>"; 
echo "<td>".$info[" 课 程 名 "]."</td>"; 
echo "<td>".$info[" 成 绩 "]."</td>"; 
echo "<td>".$info[" 班 级 编号 "]."</td>"; 
echo "<td>".$info[" 开 课 学 期 "]."</td>"; 
echo "<td>".$info[" 学 时 "]."</td>"; 
echo "<td>".$info[" 学 分 "]."</td>"; 
echo "<td>".$info[" 课 程 号 "]."</td></tr>"; 
1 
echo "</table>"; 
MySql_close($id); 


7.5 本 章 小 结 


介绍 了 PHP+MYSQL 编程 的 具体 方法 和 步骤 ， 其 中 重点 叙述 了 常用 的 操作 
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MySQL 数据 库 的 函数 功能 及 用 法 。 本 章 详尽 地 罗列 出 了 所 有 案例 的 程序 代码 , 希望 读者 能 
尽快 掌握 在 PHP 中 操作 MySQL 数据 库 的 方法 。 


7.6 练习 题 


. 简 述 在 PHP 中 怎样 连接 MySQL 服务 器 。 

. 在 PHP 中 怎样 选择 MySQL 数据 库 ? 

请 详细 叙述 MySql_query0 函 数 的 功能 和 具体 用 法 。 

请 分 别 叙述 MySql_fetch_array0、MySql_num rowsO 函 数 的 含义 和 具体 用 法 。 


上 PP 一 


77 上 机 实战 


添加 及 完善 7.4 节 中 的 学 生 网 上 成 绩 查 询 系统 部 分 功能 ， 要 求 为 该 系统 增加 一 个 用 户 
登录 页 面 ， 合 法 用 户 登 录 成 功 后 ， 系 统 自动 转 到 成 绩 查 询 页 面 实现 成 绩 查 询 ， 请 在 原 数据 
库 中 添加 用 户 表 〈t_users) ， 其 结构 如 表 7-2 所 示 ， 然 后 设计 登录 页 面 及 程序 ， 以 实现 上 
述 系统 功能 。 

表 7-2 用 户 表 (t_users) 结构 


登录 密码 
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第 8 章 PHP 中 的 正则 表达 式 及 式样 匹配 


知识 点 : 


正则 表达 式 概念 
模式 匹配 的 使 用 
正则 表达 式 的 编写 
正则 表达 式 搜索 和 替换 
利用 正则 表达 式 分 割 字 符 囊 
本 章 导读 : 

正则 表达 式 为 PHP 提供 了 功能 强大 、 灵 活 而 又 高 效 的 文本 处 理 方法 ， 它 允许 用 户 通过 
使 用 一 系列 特殊 的 字符 构建 匹配 模式 ， 然 后 把 匹配 模式 与 数据 文件 、 程 序 输入 以 及 来 自 客 
户 端 网 页 中 的 表单 输入 数据 等 目标 对 象 进行 比较 , 最 后 根据 比较 对 象 中 是 否 包含 匹配 模式 ， 
来 执行 字符 串 的 提取 、 编 辑 、 替 换 或 删除 等 操作 。 


回回 罗网 加 


8.1 正则 表达 式 简介 


PHP 同时 使 用 两 套 正则 表达 式 规则 ， 一 套 是 由 电气 和 电子 工程 师 协会 (IEEE) 制定 的 
POSIX 兼容 正则 表达 式 规则 ， 另 一 套 来 自 PCRE (Perl Compatible Regular Expression) 提 
供 的 PERL 兼容 正则 表达 式 规则 。 


8.1.1 正则 表达 式 概念 


正则 表达 式 (Regular Expression) ， 又 称 正规 表达 式 ， 简 单 地 说 ， 就 是 由 若干 字符 组 
成 的 单个 字符 串 ， 它 可 以 描述 或 者 匹配 一 系列 符合 某 个 句法 规则 的 字符 串 。 在 多 数 文本 编 
辑 器 及 其 他 工具 中 ， 正 则 表达 式 通常 被 用 来 检索 或 替换 那些 符合 某 个 模式 的 文本 内 容 。 正 
则 表达 式 由 一 些 普 通 字符 和 一 些 元 字符 组 成 。 其 中 ， 不 同 的 元 字符 代表 不 同 的 特殊 含义 ， 
它们 是 实现 模式 的 编码 ;普通 字符 包括 大 小 写字 母 和 数字 ， 大 多 数 数 字 字 符 在 模式 中 表示 
它们 自身 并 匹配 目标 中 相应 的 字符 。 例 如 ， 判 断 一 个 身份 证 号 码 是 否 合法 的 正则 表达 式 可 
以 写成 如 下 形式 : 

ereg("/(^([d1{15}[d}{18}[d}{17}x)$)") 


其 中 ，15、18、17 为 普通 字符 ， 而 ^、[]、$、{、} 等 为 元 字符 。 元 字符 并 不 代表 其 自 
身 ， 它 们 用 一 些 特殊 的 方式 来 解析 。 
元 字符 分 为 两 种 ， 一 种 是 模式 中 除了 方 括号 内 的 都 能 被 识别 ， 另 一 种 是 在 方 括号 内 被 


了 PHP Web 开发 实用 教程 


识别 的 ， 模 式 中 方 括号 内 的 部 分 称 为 字符 类 。 要 正确 编写 正则 表达 式 ， 就 必须 首先 掌握 有 
关 元 字符 的 知识 。 表 8-1 中 列 出 了 各 元 字符 的 功能 及 其 用 法 的 简单 示例 ， 建 议 读者 仔细 阅 
读本 表 ， 并 仔细 阅读 和 理解 所 列 出 的 相应 例子 。 


表 8-1 正则 表达 式 中 的 元 字符 列表 


元 字 符 | 在 方 括号 内 /外 功能 描述 及 示例 

_( 圆 点 ) 外 匹配 任何 单个 字符 。 例如 ， 正则 表达 式 ct 匹配 字符 串 : cat、cut、ct (中 
间 是 一 个 空格 ) ， 但 是 不 匹配 cost 

匹配 字符 串 的 结尾 (或 在 多 行 模式 下 行 的 结尾 , 即 紧 随 在 换行 符 之 前 ) 。 
$ 外 例如 ， 正 则 表达 式 weasel$ 能 够 匹配 字符 串 "He's a weasel" 的 末尾 ， 但 是 
不 能 匹配 字符 串 "They are a bunch of weasels." 

匹配 字符 串 的 开始 (或 在 多 行 模式 下 行 的 开头 , 即 紧 随 在 换行 符 之 后 ) 。 
^ 外 例如 , 正则 表达 式 ^When in 能 够 匹配 字符 串 "When in the course of human 
events" 的 开始 ， 但 是 不 能 匹配 "What and When in the" 

匹配 0 或 多 个 的 数量 限定 符 。 例 如 ， 正 则 表达 式 .*， 意 味 着 能 够 匹配 任 


外 意 数量 的 任何 字符 
有 数 种 用 途 的 通用 转 义 符 , 用 来 将 这 里 列 出 的 这 些 元 字符 当 作 普 通 的 字 


符 来 进行 匹配 。 例 如 ， 正 则 表达 式 \$ 被 用 来 匹配 美元 符号 ， 而 不 是 行 尾 
匹配 括号 中 的 任何 一 个 字符 。 例 如 ， 正 则 表达 式 raou]t 匹配 rat、rot 和 
mt, 但 是 不 匹配 ret。 可 以 在 括号 中 使 用 连 字符 -来 指定 字符 的 区 间 。 例 如 ， 
正则 表达 式 [0-9] 可 以 匹配 任何 数字 字符 ， 还 可 以 制定 多 个 区 间 ， 例 如 ， 
[] 外 正则 表达 式 [A-Za-z] 可 以 匹配 任何 大 小 写字 母 。 另 一 个 重要 的 用 法 是 “ 排 
除 ”， 要 想 匹 配 除 了 指定 区 间 之 外 的 字符 ， 则 在 左边 的 括号 和 第 一 个 字符 
之 间 使 用 ^ 字 符 ， 例 如 ， 正 则 表达 式 [^269A-2] 将 匹配 除了 2、6、9 和 所 有 
大 写字 母 之 外 的 任何 字符 

匹配 词 (word) 的 开始 〈\<) 和 结束 (>) 。 例 如 ， 正 则 表达 式 \<thev> 
< 这 外 能 够 匹配 字符 串 "for the wise" 中 的 "the"， 但 是 不 能 匹配 字符 串 
"otherwise" 中 的 "the" 

用 来 定义 子 模式 ， 其 中 在 括号 内 的 称 为 一 个 子 模式 。 如 在 " 


人 外 | qo-91(4-(0.910.2))-(0.9](1.2))" 中 定义 了 3 个子 模式 
开始 一 个 多 选 一 的 分 支 。 将 两 个 匹配 条 件 进行 逻辑 或 运算 。 例 如 ， 正 则 
| 外 表达 式 (himlher) 匹配 "itbelongs to him" 和 "it belongs to her", 但 是 不 能 匹 
配 "it belongs to them." 
十 外 匹配 1 或 多 个 的 数量 限定 符 。 例 如 ， 正 则 表达 式 9+ 匹 配 9、99、999 等 
外 匹配 0 或 1 个 正好 在 它 之 前 的 任意 字符 。 例如， 正则 表达 式 a?， 可 以 匹 
配 a、ab、ac， 但 不 能 匹配 abc 
匹配 指定 数目 的 字符 ， 这 些 字符 是 在 它 之 前 的 表达 式 定义 的 。 例 如 ， 正 
0 外 则 表达 式 A[0-9]{3} 能 够 匹配 字符 "A" 后 面 跟着 正好 3 个 数字 字符 的 串 ， 
让 如 A1l23、A348 等 , 但 是 不 匹配 A1234。 而 正则 表达 式 [0-9]{4,6} 匹配 连 
续 的 至 少 4 个、 最 多 6 个 数字 字符 
\ 内 通用 转 义 字符 。\\ 匹 配 反 斜 线 “\” 
册 排除 字符 类 (逻辑 非 ), 但 仅 当 其 作为 第 一 个 字符 时 有 效 。 如 [^a-zA-Z]， 
表示 匹配 一 个 非 字 母 的 字符 串 
内 指定 字符 范围 。 如 [0-9]， 可 以 匹配 0~9 的 任意 数字 
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表 8-1 介绍 的 几 种 元 字符 中 ， 反 和 斜 线 是 一 类 特殊 的 字符 ， 大 致 有 以 下 4 类 用 途 。 


口 


第 一 类 
身 ， 此 


途 就 是 用 它 后 面 跟 的 非 字母 或 数字 的 特殊 符号 来 代替 这 些 特 殊 符 号 本 
时 它 相当 于 C 语言 的 转 义 字符 ， 在 方 括号 内 外 都 适用 ， 如 表达 式 “\*” 将 


被 转 义 成 “*” 本 身 ， 而 “\\” 表 示 “\” 本 身 。 


第 二 类 


用 途 是 提供 一 种 在 模式 中 以 可 见方 式 编码 不 可 打印 字符 的 方法 ， 如 “\n” 


匹配 一 个 换行 符 ，“\ ”匹配 一 个 制 表 符 。 


第 三 类 用 途 是 指定 通用 字符 类 型 ， 如 “\d” 表 示 任 一 十 进 制 数字 ，“\D ”表示 任 
一 非 十 进 制 数 的 字符 。 


第 四 类 用 途 是 用 来 标识 某 些 简单 的 断言 ， 所 谓 断 言 是 指 在 一 个 匹配 中 的 特定 位 置 
必须 符合 某 种 特定 的 条 件 ， 常 见 的 反 斜 线 断言 有 : “\A” 表 示 字 符 串 开头 ，“\Z” 
表示 字符 串 结尾 或 行 尾 ，“\z” 表 示 字 符 串 结尾 等 。 

如 表 8-2 所 示 总 结 了 以 上 4 类 作用 的 反 斜 线 转 义 功能 。 


表 8-2 反 斜 线 通 常用 到 的 转 义 序列 所 表示 的 字符 列表 


字符 描 述 

癌 匹配 一 个 单词 边界 , 也 就 是 指 单词 和 空格 间 的 位 置 。 例如 , 'erb' 可 以 匹配 "never" 中 的 'er， 
但 不 能 匹配 "verb" 中 的 'er' 

\B 匹配 非 单词 边界 。'en\B' 能 匹配 "verb" 中 的 'er， 但 不 能 匹配 "never" 中 的 'er' 

局 匹配 由 X 指明 的 控制 字符 。 例 如 ，\cM' 匹 配 一 个 Control-M 或 回 车 符 。x 的 值 必须 为 A 一 
Z 或 a~z 之 一 ; 硅 则 ， 将 'c' 视 为 一 个 原 义 的 'c' 字 符 

\d 匹配 一 个 数字 字符 。 等 价 于 '[0-9] 

\D 匹配 一 个 非 数字 字符 。 等 价 于 '[^0-9 

¥ 匹配 一 个 换 页 符 。 等 价 于 "x0c' 和 "cL' 

nh 匹配 一 个 换行 符 。 等 价 于 \x0a' 和 "\cJ 

Yr 匹配 一 个 回 车 符 。 等 价 于 "x0d' 和 \eM 

\s 匹配 任何 空白 字符 ， 包 括 空格 、 制 表 符 、 换 页 符 等 。 等 价 于 '[ \fmrtwv]， 

\S 匹配 任何 非 空白 字符 。 等 价 于 ' [^ ftwv]， 

Vt 匹配 一 个 制 表 符 。 等 价 于 \x09' 和 "ce 

YY 匹配 一 个 垂直 制 表 符 。 等 价 于 \x0b' 和 \cK' 

\w 匹配 包括 下 划 线 的 任何 单词 字符 。 等 价 于 '[A-Za-z0-9 】 

\W 匹配 任何 非 单词 字符 ， 等 价 于 '[^A-Za-z0-9 ] 

ee 匹配 n, 其 中 为 十 六 进 制 转 义 值 .十 六 进 制 转 义 值 必须 为 确定 的 两 个 数字 长 。 例 如, \x41' 
匹配 "A"，"\x041' 则 等 价 于 "x04' & "1"。 正 则 表达 式 中 可 以 使 用 ASCII 编码 

匹配 num， 其 中 num 是 一 个 正 整数 ， 对 所 获取 的 匹配 的 引用 。 例 如 ，'()NL 匹 配 两 个 连续 
的 相同 字符 

国 标志 一 个 八进制 转 义 值 或 一 个 后 向 引用 。 如 果 \ 之 前 至 少 有 n 个 获取 的 子 表达 式 ， 则 n 
为 后 向 引用 ; 否则 ， 如 果 n 为 八进制 数字 〈0 一 7) ， 则 n 为 一 个 八进制 转 义 值 
示 志 一 个 八进制 转 义 值 或 一 个 后 向 引用 。 如 果 \nm 之 前 至 少 有 nm 个 获取 的 子 表达 式 ， 则 

nm 为 后 向 引用 。 如果 \nm 之 前 至 少 有 mn 个 获取 ， 则 了 为 一 个 后 跟 文 字 m 的 后 向 引用 。 如 


果 前 面 的 条 件 都 不 满足 ， 若 n 和 m 均 为 八进制 数字 (0 一 7) ， 则 \nm 将 匹配 八进制 转 义 
值 nm 
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续 表 
字符 描述 
如 果 n 为 八进制 数字 (0~3) ， 且 m 和 1 均 为 八进制 数字 (0 一 7) ， 则 匹配 八进制 转 
ml 2 
义 值 nml 
匹配 n， 其 中 是 用 4 个 十 六 进 制 数字 表示 的 Unicode 字符 。 例 如 ，\u00A9' 匹 配 版 权 
符号 〈@) 
\xhh 十 六 进 制 代码 为 hh 的 字符 
\ddd 八进制 代码 为 ddd 的 字符 


8.1.2 ”常用 的 正则 表达 式 及 举例 


在 设计 Web 程序 时 ， 经 常 要 用 正则 表达 式 ， 表 8-3 列 出 了 其 中 比较 常见 和 实用 的 正则 
表达 式 ， 读 者 在 今后 设计 网 站 项 目 时 可 以 用 作 参 考 。 


要 匹配 的 内 容 
网 址 URL 
年 -月 -日 


全 地 址 

中 文字 符 
空 行 

HTML 标记 
首尾 空格 
Email 地 址 


腾讯 QQ 号 
邮政 编码 
电话 号 但 
手机 号 码 
SQL 语 名 
允许 以 字母 开头 ， 由 字母 、 数 
字 、 下 划 线 组 成 的 5 一 16 个 字 
节 的 账号 信息 


表 8-3 常见 实用 的 正则 表达 式 
正则 表达 式 
A[a-zA-z]+: /CCwW+(-VW+)*#)(CCWH+(-VW 十 )#))#(\2NS#)99 
人 df{4}-(0?\dll12[012])-(0?\dl[12]\dl3[01]D)S/ 
Md{1,2}|1dd|l2[0-4]dl25[0-5).(d{1,2}l1dd|2[0-4]d|25[0-5D).(d{1,2}|1dd|2[0-4] 
dl25[0-5]).(df12}|11ddl2[0-4]dl25[0-5])$ 
\u4e00-\u9fa5 
ns| ]*r 
/<(.*)>.*<WA1>|<(.*) V>/ 
(Ns*)IQs*$) 
Ew-.)@CLLO-9]{1,3}.[0-9]{1,3}.[0-9]{1,3} (Ew-]+.)+))([a-zA-2]{2, 
4}|[0-9]{1,3)07)8" 
^[1-9]*[1-9][0-9]*$ 
^[1-9Nd{5}$ 
^((0d{2,37)04{37 -00d{2,37VI0\d{2,3}-)?[1-9Nd{6,7}(\d{1,4})78$ 
(CCdf2.3}NIlCdf3}-))213\df9}9 
^(selectldropldeletelcreatelupdatelinsert).*$ 


^[a-zA-Z][a-zA-Z0-9 ]{4.15}$ 


中 文 、 英 文 、 数 字 及 下 划 线 


^[\u4e00-\u9fa5 a-zA-Z0-9]+$ 


下 面 通过 一 个 常见 的 电话 号 码 验 证 程序 来 简单 曾 述 表 8-3 中 的 部 分 正则 表达 式 。 该 程 


序 要 求 用 


户 设置 合法 的 电话 号 码 , 程序 中 将 用 到 内 置 函数 preg _ matchO〈 在 8.2.1 小 节 中 将 做 


详细 介绍 ， 这 里 只 简单 叙述 一 下 ) 。 该 函数 用 来 执行 正则 表达 式 的 搜索 ， 其 语法 格式 如 下 : 
int preg_match( string pattern, string subject [, array matches [, int flags]] ) 
其 功能 是 在 subject 字符 串 中 搜索 与 pattem 给 出 的 正则 表达 式 相 匹配 的 内 容 。 
preg_match() 函 数 返回 pattem 所 匹配 的 次 数 。 一 般 返 回 值 只 有 两 个 : 0 (没有 匹配 ) 和 1〈 匹 
配 ) 次， 因为 preg_ matchO 函 数 在 第 一 次 匹配 之 后 将 停止 搜索 ， 程 序 代码 如 下 : 
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<html> 

<head> 

<title> 电 话 号 码 验 证 程序 </title> 

</head> 

<body> 

<form name="frm1" method="post" action=""> 

<div align="center"><font size="4" color="green"> 电 话 号 码 验 证 程序 </font></div> 
<table border="1" width=480 align="center > 

<tr><td width=80> 电 话 号 码 : </td> 

<td><input type="text" name="TELPHID"> 

<td class="STYLE1">* 请 输入 中 国 大 陆地 区 的 电话 号 码 </td></tr> 
<tr><td colspan="3" align="center > 

<input type="submit" name="smt" value=" 提 交 ">&nbsp;&nbsp;&nbsp; 
<input type="reset" name="NO" value=" 取 消 "></td></tr> 

</table> 

</form> 

</body> 

</html> 

<?php 

iflisset($_POST['smt"])) 

{ 


$id=$_POST[TELPHID'; 
// 检 查 电话 号 码 
Schecktelphno=preg_match(/*((\(\d{2,3})I(d{3}-))? (0\d{2,3})10\d{2,3}-)?[1-9N\d{6,7}(\\d{1, 
4))2$1,$id): 
if(I$checktelphno) 
echo "<script>alert(' 电 话 号 码 格 式 不 对 ! ')</script>"; 
else 
echo "<script>alert(' 此 数字 为 电话 号 码 ! ')</script>"; 


?> 


本 程序 运行 后 的 效果 如 图 8-1 和 图 8-2 所 示 。 


三 电话 号 凤 验 下 程 序 -Window TInternet Erplore 电话 号 码 验 证 要 序 Vindovs TREE 全 
Ov [evn ewe msl) x | 5E 
上 交 件 如 并 性 D、 查 看 W) 中 这 天 加 ”工具 人 助人 i 
襄 收 革 玉 。 下 电话 3 友好 得 | 画 


电话 号 码 验证 程序 程序 


| 国有 而 二 


Li | Ed 加 mtrnet [ L pr I 


图 8-1 新 用 户 注 册页 面 图 8-2” 当 输入 不 符合 规范 的 电话 号 码 时 弹出 的 对 话 框 
8.2 ”模式 匹配 函数 


8.1 节 中 介绍 了 由 普通 字符 和 元 字符 一 起 组 成 的 匹配 模式 , 但 光 有 模式 是 不 能 做 任何 事 
情 的 ， 它 必须 与 函数 相配 合 才 能 起 作用 。 正 如 8.1.2 中 的 电话 号 码 验证 程序 示例 中 用 到 的 
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preg_match() 一 样 ,在 该 函数 中 ,用 由 正则 表达 式 组 成 的 匹配 模式 作为 参数 ,然后 preg_match() 
就 按 这 个 模式 来 搜索 目标 字符 。 下 面 将 详细 介绍 常见 的 模式 匹配 函数 。 


8.2.1 ”匹配 字符 串 


正则 表达 式 编写 完 以 后 就 可 以 使 用 模式 匹配 函数 来 处 理 指定 字符 串 ， 其 中 ， 字 符 串 的 
匹配 是 正则 表达 式 的 主要 应 用 之 一 。 在 PHP 中 ， 和 preg_match() 函 数 功 能 类 似 的 还 有 两 个 
函数 : ereg0 和 eregi0) 函 数 ， 它 们 也 是 用 于 匹配 正则 表达 式 的 。preg_match0 函 数 是 Perl 兼 
容 的 正则 表达 式 函 数 ， 而 ereg0 和 eregi0 函 数 是 POSIX 扩展 的 正则 表达 式 函数 。 


1，preg_match() 函 数 
在 Perl 兼容 的 正则 表达 式 中 使 用 preg_match0 函 数 进行 字符 串 的 查找 , 其 语法 格式 如 下 : 


int preg_ match(string pattern , string subject [, array matches [, int flags ]]) 

preg_match0) 函 数 的 功能 是 : 在 subject 字符 串 中 搜索 与 patterm 给 出 的 正则 表达 式 相 匹 
配 的 内 容 ， 如 果 搜 索 到 ， 则 返回 与 pattern 匹配 的 次 数 。 由 于 preg_match() 函 数 在 第 一 次 匹 
配 成 功 之 后 将 停止 搜索 ， 因 此 最 后 返回 的 值 要 么 是 0 (没有 匹配 ) ， 要 么 是 1。 如 果 带 有 可 
选 的 第 3 个 参数 matches， 则 可 以 把 匹配 的 部 分 存在 一 个 数组 中 ， 可 选 参数 flags 表示 数组 
matches 的 长 度 ， 如 果 为 0( 即 为 数组 matches[0]) ， 则 数组 将 包含 与 整个 模式 匹配 的 文本 ; 
如 果 为 1 ( 即 为 数组 matches[1]) ， 则 数组 将 包含 与 第 一 个 捕获 的 括号 中 的 子 模式 所 匹配 的 
文本 ， 依 此 类 推 。 例 如 ， 下 列 程序 代码 : 


<?php 

Sstring="http://www.cec.edu.cn/index.html"; 

preg_match('/^(http:\?/?\?/)?([A\?/]+)/i', $string, $matchesf); /从 URL 中 取得 主机 名 

echo $matchesf[0]; /输出 http://www.cec.edu.cn 
$host = $matchesf[2]; 

echo $host; /输出 /www.cec.edu.cn 
preg_match(V[A\?/+\[AV\2/]+$/, $host, $matchess); // 从 主机 名 中 取得 后 面 两 段 
echo "域名 为 : $matchess[0]"; // 输 出 域名 为 :cec.edu.cn 
?> 


2.，ereg() 函 数 与 eregi() 函 数 


使 用 eregO 函 数 可 以 查找 字符 串 与 子 字符 串 匹 配 的 情况 ,并 返回 匹配 字符 串 的 长 度 , 还 
可 以 借助 参数 返回 匹配 字符 的 数组 。 语 法 格式 如 下 : 

bool ereg(string (pattermn) , string string [, array regs ]) 

该 函数 对 字符 串 string 进行 查找 ， 如 果 找 到 与 给 定 正则 表达 式 pattem 相 匹 配 的 子 字符 
串 ， 则 返回 TRUE， 否 则 返回 FALSE。pattem 中 可 以 使 用 圆 括号 “0” 将 一 些 子 模式 括 起 
获取 这 一 匹配 。 如 果 找 到 与 pattem 圆 括号 内 的 子 模式 相 匹配 的 子 串 ， 并 且 函 数 调 用 给 出 
了 第 3 个 参数 regs， 则 匹配 项 将 被 存 入 regs 数组 中 。regs[0] 包 含 整个 匹配 的 字符 串 , regs[1] 
包含 第 一 个 左 圆 括号 开始 的 子 串 ，regs[2] 包 含 第 二 个 子 串 ， 依 此 类 推 。 如 果 在 string 中 找到 
pattern 模式 的 匹配 , 则 返回 所 匹配 字符 串 的 长 度 , 如 果 没有 找到 匹配 或 出 错 则 返回 FALSE。 
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如 果 没 有 传 入 可 选 参数 regs 或 者 所 匹配 的 字符 串 长 度 为 


<?php 
Stoday="2008-08-08"; 


Slen=ereg (([0-9]{4})-([0-9]{1,2})-([0-9]{1,2})', $today, $regs); 


if ($len) 


echo "$regs[3]. $regs[2].$regs[1]". "<br>"; 
echo $regs[0] ."<br>"; 
echo $len; 


0， 则 本 函数 返回 1。 例 如 : 


/日 期 格式 为 年 -月 -日 


/输出 "08.08.2008" 
1/ 输 出 "2008-08-08" 
// 输 出 10 


} 


else 


echo "错误 的 日 期 格式 : $today "; 
1 


?> 


运行 结果 如 图 8-3 所 示 。 


这 收藏 严 及 ereg0 函 涩 


08. 08. 2008 
2008-08-08 
10 


图 8-3 ”ereg0 函 数 的 应 用 
eregi0 函 数 与 ereg0) 函 数 类 似 ， 但 它 在 进行 匹配 时 会 忽略 字符 的 大 小 写 ， 这 里 不 再 袭 述 。 
8.2.2 ”替换 字符 串 


用 于 替换 字符 串 的 函数 主要 有 两 个 ， 一 个 是 preg_replace0 函 数 ， 它 是 Perl 兼容 正则 表 
达 式 图 数 ， 另 一 个 是 ereg_replace0) 函 数 ， 它 是 POSIX 扩展 正则 表达 式 函 数 。 


1. preg_replace() 函 数 

该 函数 执行 正则 表达 式 的 搜索 和 替换 ， 其 语法 格式 如 下 : 

mixed preg replace(mixed patterm, mixed replacement, mixed subject [, int limit]) 

其 中 ，replacement 中 可 以 包含 形 如 “\n” 或 “Sn” 的 逆向 引用 ，Sn 取 值 1 一 99， 优 先 
使 用 后 者 。 这 里 先 说 说 什么 是 逆向 引用 : 它 是 通过 反 和 斜 线 转 义 的 数字 ， 该 数字 指出 当前 表 
达 式 应 该 再 次 匹配 它 已 经 查找 到 的 这 个 序列 。 此 时 ， 逆 向 引用 的 数目 n 指定 当前 正则 表达 
式 中 从 左 往 右 数 ， 第 n 个 圆 括号 括 起 来 的 子 模式 应 当 替 换 它 在 字符 串 中 所 匹配 的 文本 。 解 
释 完 了 逆向 引用 ， 再 回 到 正题 ， 替 换 模式 在 一 个 逆向 引用 后 面 紧 接着 一 个 数字 时 ( 即 紧 接 
在 一 个 匹配 的 模式 后 面 的 数字 ) ， 最 好 不 要 使 用 “\m” 来 表示 逆向 引用 。 例 如 ，“\11”， 
将 会 使 preg_replace0) 函 数 无 法 分 清 是 一 个 “W1” 的 逆向 引用 后 面 跟着 一 个 数字 1， 还 是 


是 一 
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个 表示 “1” 的 进 间 引用 。 解 决 方法 是 使 用 “St01”。 这 会 形成 个 阴 训 的 “$1” 适 和 
引用 ， 而 另 一 个 “1” 只 是 单纯 的 字符 。 例 如 

<?php 

S$str="<h1>| love china</h1>"; 

echo preg_replace(/<(.*?)>/", "($1)",$str); /输出 '(h1) 1 love china (/h1)' 

?> 


2. ereg_replace() 函 数 


ereg_replace() 是 POSIX 风格 的 正则 表达 式 函 | 它 与 第 4 章 中 讲 到 的 str_replace0 函 数 
一 样 ， 可 以 将 查找 到 的 字符 串 蔡 换 为 指定 字符 串 。 与 str_replace0O 不 同 的 是 ，ereg_replace() 
函数 能 实现 更 为 复杂 的 字符 串 操作 。ereg 1 iasg 庆 数 的 语法 格式 如 下 : 

string ereg_replace(string $pattern , string $replacement , string $string) 

其 中 ， 参 数 $replacement 表示 替换 字 串 时 要 用 到 的 字符 ， 其 功能 是 : 使 用 字符 串 
S$replacement 替换 字符 串 $string 中 与 Spattern 匹配 的 部 分 并 返回 替换 后 的 字符 串 。 如 果 没 有 
可 供 替 换 的 匹配 项 则 返回 原 字 符 串 。 例 如 : 

<?php 

$stra="hello world"; 

echo ereg_replace('[Iro]', 'y', $stra). "<br>"; 

$resrc='<a href=\"world.php\">hello</a>"; 


echo ereg_replace('hello', $resrc,$stra); // 用 一 个 超 链接 蔡 换 'hello' 字 符 
?> 


该 程序 的 运行 结果 如 图 8-4 所 示 。 


ce 〇 函数 一 Windors Jnter 


个 全- 0 :oreeychaps_3 php 到 1 好 xj 由 e sine 


党 收 着 夹 。 及 eree_replace 0 函数 


heyyy wyyyd 
hello world 


图 8-4 ”ereg_replace 函数 的 应 用 
8.2.3 用 正则 表达 式 分 割 字符 串 
PHP 程序 支持 两 种 用 于 对 字符 串 进行 分 割 的 正则 表达 式 函 数 ， 一 种 是 Perl 兼容 正则 表 
达 式 函数 preg_split0， 另 一 种 是 POSIX 扩展 正则 表达 式 函数 split()。 
1. preg_split() 函 数 


该 函数 功能 是 用 正则 表达 式 来 分 割 指定 的 字符 串 ， 语 法 格式 如 下 : 

array preg_split(string $pattern , string $subject [, int Slimit [, int $flags ]]) 

本 函数 区 分 大 小 写 ， 返 回 一 个 数组 ， 其 中 包含 Ssubject 中 沿 着 与 Spattem 匹配 的 边界 所 
分 割 的 子囊 。 如 果 指 定 了 可 选 参数 Slimit， 则 最 多 返回 Slimit 个 子 串 ， 如 果 省 略 或 为 -1， 则 
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没有 限制 。 可 选 参数 $flags 的 值 可 以 是 以 下 3 种 。 

口 PREG SPLIT NO_EMPTY: 如 果 设 定 本 标记 ， 则 函数 只 返回 非 空 的 字符 串 。 

口 PREG SPLIT DELIM CAPTURE: 如 果 设 定 本 标记 ， 定 界 符 模 式 中 的 括号 表达 式 

的 匹配 项 也 会 被 捕获 并 返回 。 

口 PREG SPLIT_ OFFSET CAPTURE: 如 果 设 定 本 标记 ， 对 每 个 出 现 的 匹配 结果 也 
同时 返回 其 附属 的 字符 串 偏 移 量 。 

例如 ， 以 下 程序 : 


<?php 

S$str="one world, one dream"; 

$priecewords = preg_split (%[\s,]+/", $str); /以 空白 符 或 逗号 作为 定 界 符 
print_r($priecewords); 

?> 


本 程序 的 运行 结果 如 图 8-5 所 示 。 


这 收藏 天 。 侯 pres_split 0 函数 


Array ( [0] => one [1] => world [2] => 
one [3] => dream ) 


图 8-5 preg_split 0 函数 的 应 用 
2. split() 函 数 


其 功能 与 preg_split(0) 函 数 类 似 ， 实现 用 正则 表达 式 对 字符 串 进行 分 割 ， 语法 格式 如 下 : 

array split(string $pattern , string $string [, int $limit ]) 

本 函数 返回 经 使 用 Spattem 作为 边界 对 字符 串 $string 进行 分 割 后 得 到 的 字符 串 数组 , 如 
果 设 定 了 $limit， 则 返回 的 数组 最 多 包含 Slimit 个 元 素 ， 而 其 中 最 后 一 个 元 素 包含 了 字符 串 
$string 中 剩余 的 所 有 部 分 ， 如 果 出 错 ， 则 返回 FALSE。 例 如 ， 以 下 程序 ; 

<?php 

$string="One .worldlone.dream_?"; 


S$array=split([ |._]', $string); 
print_r($array); 


?> 

本 程序 的 运行 结果 如 图 8-6 所 示 。 
/pree_split 0 函数 Windorsi1tee -lolxl 
GO br re | 0 6 I 
训 收 三 天 。 术 preg split 0 函数 | 


Array ( [0] => One [1] => [2] => world 
[3] => one [4] => dream [5] = ? ) 


图 8-6 ”split0 函 数 的 应 用 
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8.2.4 转 义 正则 表达 式 字符 


preg_quote0 函 数 可 以 使 正则 表达 式 中 的 特殊 字符 变 成 普通 字符 ， 其 语法 格式 如 下 : 

string preg_quote(string str[,string delimiter]) 

其 中 ， 参 数 str 表示 需 转 换 的 字符 串 ， 函 数 处 理 结 果 是 将 字符 串 str 中 每 个 属于 正则 表 

达 式 语法 的 字符 前 面 加 上 一 个 反 斜 线 。 如 果 需 要 以 动态 生成 的 字符 串 作 为 模式 去 匹配 ， 则 

可 以 用 此 函数 转 义 其 中 可 能 包含 的 特殊 字符 。 如 果 提 供 了 可 选 参数 delimiter， 则 该 字符 也 
将 被 转 义 。 下 面 举例 说 明 如 何 利用 preg_quoteO 函 数 来 转 义 正则 表达 式 中 的 字符 。 

<?php 

S$pattern="$60 for a A3/400"; 1/ 获取 当前 网 页 在 服务 器 中 的 地 址 

S$transeout=preg_quote($pattern,"/"); 

echo "此 时 pattern 的 内 容 为 : <br/>"; 

echo $pattern."<br/>"; 


echo "经 过 preg_quote 函数 处 理 过 的 结果 为 : ".$transeout' 
?> 


本 程序 的 运行 结果 如 图 8-7 所 示 。 


/preg_quote 站 函数 - Windows Internet Ezplorea 


GO- 检 ‘ooksource/chap8 6. php #7) x | Bine 


这 收藏 交心 prec_auote0 函 数 


此 时 pattern 的 内 容 为 ， 
$60 for a A3V40 


0 
经 过 preg_quote 函 数 处 理 过 的 结果 为 ，\$60 for a A3\/400 


图 8-7 preg_quote0 函 数 的 应 用 
8.3 案例 剖析 : 新 用 户 注册 程序 


网 上 注册 新 用 户 是 比较 常见 的 Web 应 用 ， 如 申请 电子 邮箱 、 申 请 网 络 论坛 账号 等 ， 都 
需要 用 户 填 写 和 提交 Web 页 面 上 的 注册 表单 。 在 这 些 注册 表单 上 ,通常 有 一 些 选项 要 求 用 
户 输入 符合 规范 的 数据 信息 ， 如 出 生日 期 、 电 子 邮 箱 、 电 话 号 码 、 邮 政 编码 等 。 这 些 选项 
的 设置 利用 正则 表达 式 来 实现 是 非常 容易 的 。 


8.3.1 程序 功能 介绍 


本 程序 首先 在 客户 端 页 面 上 生成 一 个 用 户 注册 的 表单 ， 要 求 客户 端 用 户 输入 自己 的 出 
生日 期 、 设 置 自己 的 用 户 号 及 密码 、 用 户 的 电子 邮箱 地 址 等 。 在 输入 以 上 信息 时 ， 如 果 存 
在 用 户 提供 的 数据 格式 不 正确 ， 则 程序 会 弹出 相关 的 提示 框 。 
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8.3.2 程序 代码 分 析 


该 例 中 要 求 用 户 设 置 合法 的 用 户 名 、 密 码 ， 并 要 求 输入 出 生日 期 、 有 效 的 邮件 地 址 等 ， 


本 程序 中 用 到 了 内 置 函 数 preg_match()， 程 序 代 码 如 下 : 


<html><head> 

<title> 新 用 户 注 册页 面 </title> 

</head> 

<body> 

<form name="frm1" method="post" action=""> 

<div align="center"><font size="4" color="green"> 新 用 户 注 册 信 息 </font></div> 
<table border="1" width=480 align="center"> 

<tr><td width=80> 用 户 号 : </td> 

<td><input type="text" name="userlD"> 

<td class="STYLE1">* 6 一 10 个 字符 (数字 ,字母 和 下 划 线 )</td></tr> 
<tr><td> 密 码 : </td> 

<td><input type="password" name="pw" size="18"></td> 

<td class="STYLE1">* 6 一 17 个 数字 </td></tr> 

<tr><td> 出 生日 期 :</td> 

<td><input type="text" name="shengri"></td> 

<td>* 有 效 的 日 期 </td></tr> 

<tr><td> 邮 箱 :</td> 

<td><input type="text" name="EMAIL"></td> 

<td >* 有 效 的 邮件 地 址 </td></tr> 

<tr><td colspan="3" align="center > 

<input type="submit" name="smt" value=" 提 交 ">&nbsp;&nbsp;&nbsp; 
<input type="reset" name="NO" value=" 取 消 "></td></tr> 

</table> 

</form> 

<?php 

if(isset($_POST['smt")) 


{ 


$id=$_POST['userlD'; 

$pwd=$_POST[pw]; 

$birthday=$_POST[shengri]; 

$Email=$_POST[EMAIL]; 

$checkid=preg_match("/^\w{6,10}$/",$id); // 检 查 是 否 为 6 一 10 个 字符 
$checkpwd=preg_match(/A\d{6,17}$/,$pwd); /检查 是 否 为 6 一 17 个 数字 

// 检 查 是 否 是 有 效 的 日 期 
$checkbirthday=preg_match(VAd{4}-(0?\dl1?[012])-(0?\dl[12]\dl3[01])$7,S$birthday); 

// 检 查 Email 地 址 的 合法 性 
$checkEmail=preg_match("/^[a-zA-Z20-9_\-]+@[a-zA-Z0-9\-]+\.[a-zA-Z0-9\-\.]+$/",$Email); 


if(!$checkid) 

echo "<script>alert( 用 户 号 格式 不 符合 规范 ! ')</script>"; 
elseif(!$checkpwd) 

echo "<script>alert(' 密 码 格 式 不 符合 规范 ! ')</script>"; 
elseif(!$checkbirthday) 


echo "<script>alert(' 出 生日 期 格式 不 符合 规范 ! ')</script>"; 
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elseif(I$checkEmail) 


echo "<script>alert( 邮 箱 格式 不 符合 规范 ! ')</script>"; 
else 
echo "注册 成 功 !"; 
} 
?> 
</body></html> 
本 程序 运行 后 的 效果 如 图 8-8 和 图 8-9 所 示 。 
= 
GO i 
」 文件 中) 坊 绢 信 ) 可 者 ! 工具 人 D 帮助 如 
训 收 8 天。 站 新 用 广 注册 页面 I 0] 
新 用 户 注册 信息 a 新 用 户 注册 信息 
RP CD Rs EL 站 于 行 (了 下， 寺 和 条 
密码 ， ee * 6~17 个 数字 密码 ， A 出生 日 期 格式 不 宰 全 规范! | 个 数字 
出 生日 期 ， [ss91022 ”i* 有 效 的 日 其 日 其 ， 的 日 其 
邮箱 ， Pearem 有 效 的 邮件 地 址 ， 二 的 邮 牢 地 址 
E32 
划 
Ea [elm ml mi Lr [rl 
图 8-8 新 用 户 注册 页 面 图 8-9 当 输 入 不 符合 规范 的 日 期 时 弹出 的 对 话 杠 
84 本 章 小 结 


本 章 介绍 了 PHP 中 的 正则 表达 式 ， 首 先 让 读者 了 解 什么 是 正则 表达 式 、 正 则 表达 式 的 
构成 、 正 则 表达 式 的 语法 等 基础 知识 ， 然 后 着 重 介绍 了 几 种 常用 的 正则 表达 式 函 数 的 功能 
和 使 用 方法 ， 最 后 通过 典型 案例 进一步 深入 讲述 正则 表达 式 的 使 用 方法 。 在 讲述 知识 点 时 
介绍 了 很 多 实际 例子 ， 希 望 读者 借助 这 些 实例 能 尽快 熟悉 正则 表达 式 的 应 用 。 


8.5 练 习 题 
1. 简 述 什么 是 正则 表达 式 。 它 由 哪 两 种 类 型 的 字符 组 成 ? 
2. Perl 兼容 正则 表达 式 与 POSIX 扩展 正则 表达 式 有 什么 区 别 ? 
3. 如 果 要 验证 中 国 大 陆地 区 居民 身份 证 号 码 是 否 符合 格式 规定 ,应 该 怎样 来 编写 正则 
表达 式 ? 
86 上 机 实战 


1. 创建 一 个 动态 网 页 ， 要 求 把 日 期 “2011-4-24” 转 换 为 “2011 年 4 月 24 日 ”。 
2. 创建 动态 网 页 程序 ， 实 现 对 中 国 大 陆地 区 电话 号 码 和 卫 地 址 有 效 性 的 验证 。 
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知识 点 : 
类 与 对 象 的 概念 
类 的 定义 与 实例 化 
类 的 成 员 与 作用 域 
类 的 继承 
类 的 重用 
本 章 导读 : 

PHP 是 面向 对 象 的 编程 语言 。 面 向 对 象 是 最 近 三 十 多 年 发 展 起 来 的 一 种 编程 思想 ， 在 
它 出 现 之 前 ， 程 序 员 往往 采用 的 是 面向 过 程 的 编程 方法 ， 这 种 方法 要 求 用 户 必 须 全 面 完整 
地 描述 其 业务 需求 ， 然 后 程序 员 根据 这 些 需 求 决定 需要 哪些 过 程 ， 确 定 实现 任务 需求 的 最 
佳 算法 ， 其 设计 的 重点 在 于 处 理 过 程 和 执行 运算 的 算法 。 面 向 过 程 编程 方法 最 大 的 缺点 是 
编程 效率 不 高 ， 可 扩展 性 差 ， 程 序 代码 的 重用 率 低 。 为 克服 面向 过 程 编 程 方法 的 缺点 ， 面 
向 对 象 编程 技术 应 运 而 生 。 


回回 罗网 加 


9.1 类 与 对 和 象 


在 本 书 第 3 章 中 讲述 了 PHP 支持 的 数据 类 型 ,其 中 有 一 种 数据 类 型 称 为 对 象 数据 类 型 ， 
此 种 数据 类 型 就 涉及 了 类 和 对 象 的 概念 。 类 和 对 象 是 面向 对 象 编程 技术 中 的 两 个 重要 概念 ， 
对 于 初学 者 来 说 可 能 有 一 点 抽象 ， 理 解 起 来 比较 困难 。 下 面 通过 现实 生活 中 的 一 些 实例 来 
讲解 这 两 个 概念 。 


9.1.1 类 的 概念 


类 描述 了 一 组 有 相同 特性 〈 属 性 ) 和 相同 行为 〈 方 法) 的 事物 。 世 界 是 怎么 构成 的 ? 
对 于 这 个 问题 ， 不 同 的 人 可 能 有 不 同 的 答案 。 化 学 家 可 能 回答 “这 个 世界 是 由 分 子 、 原 子 、 
离子 等 化 学 物质 组 成 的 ”; 画家 可 能 回答 “这 个 世界 是 由 不 同 的 颜色 所 组 成 的 ”; 但 如 果 
让 一 个 分 类 学 家 来 回答 这 个 问题 , 他 可 能 会 说 “这 个 世界 是 由 不 同类 型 的 物 与 事 所 构成 的 ”。 
作为 程序 员 来 说 ， 在 实际 编程 过 程 中 就 应 该 站 在 分 类 学 家 的 角度 去 考虑 问题 。 现 在 ， 我 们 
站 在 分 类 学 家 的 角度 去 回答 这 个 问题 ， 世 界 是 由 动物 、 植 物 等 组 成 的 ， 动 物 又 分 为 单 细胞 
动物 、 多 细胞 动物 、 哺 乳 动物 等 ， 哺 乳 动 物 又 分 为 人 、 大 象 、 老 虎 …… 就 这 样 分 下 去 我 们 
会 发 现 ， 世 界 由 很 多 类 事物 组 成 ， 每 类 事物 都 有 自己 独 有 的 特性 。 或 者 说 ， 同 一 类 事物 具 
有 共同 的 特性 。 这 就 好 比 华南 虎 、 东 北 虎 都 属于 老虎 类 。 这 里 ， 老 虎 是 一 个 类 ， 华 南 虎 则 
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属于 类 中 的 一 个 具体 的 对 象 。 

面向 过 程 的 编程 语言 与 面向 对 象 的 编程 语言 的 区 别 就 在 于 : 面向 过 程 的 语言 不 允许 程 
序 员 自 己 定义 数据 类 型 ， 只 能 使 用 程序 中 内 置 的 数据 类 型 ， 而 面向 对 象 编程 提供 了 类 的 概 
念 ， 程 序 员 可 以 根据 需要 自由 地 定义 数据 类 型 〈 即 类 ) 。 通 过 类 ， 程 序 员 可 以 将 某 软件 项 
目 模拟 成 真实 世界 ， 从 而 设计 出 更 加 科学 、 合 理 的 解决 方案 来 。 

例如 ， 要 用 PHP 设计 一 个 学 生 管理 软件 系统 ， 如 果 要 用 面向 对 象 编程 方 法 来 实现 ， 则 
应 该 在 PHP 程序 中 至 少 要 创建 一 个 学 生 类 student, 然后 为 这 个 类 定义 共有 属性 ， 如 学 生 姓 
名 、 性 别 、 年 龄 、 籍 员 、 家 庭 住址 等 ， 然 后 还 要 定义 所 具有 的 行为 (在 程序 设计 中 称 为 方 
法 ) ， 如 学 生 选 课 、 上 课 、 考 试 等 。student 类 定义 好 后 ， 就 可 以 在 接 下 来 的 代码 编写 中 使 
用 这 个 类 。 定 义 完毕 学 生 类 之 后 ， 如 果 想 让 这 个 学 生 类 像 现实 生活 中 真实 的 学 生 一 样 动 起 
来 ， 还 必须 将 这 个 类 实例 化 ， 即 创建 一 个 属于 该 类 的 对 象 ， 接 下 来 就 可 以 让 这 个 对 象 根据 
定义 的 行为 方法) 内容 动 起 来 。 


9.1.2 ”对象 


前 面 讲 了 有 关 类 的 概念 。 创 建 完毕 类 ， 只 是 完成 了 对 一 些 具有 相同 属性 和 行为 的 事物 
的 定义 ， 要 想 让 所 定义 的 类 具有 实际 意义 ， 必 须要 创建 一 个 属于 该 类 的 具体 对 象 ， 如 果 把 
类 比 作 模 板 ， 则 对 象 就 是 基于 该 模板 的 一 个 实例 。 例如， 学 生 是 一 个 类 ， 其 中 有 个 男 学 生 ， 
姓名 叫 张 三 ， 则 张 三 是 学 生 类 的 一 个 具体 的 、 实 实在 在 存在 的 人 ， 是 学 生 类 的 一 个 对 象 。 
又 如 ， 全 世界 的 雇员 可 以 归结 为 一 个 类 ， 则 一 名 叫 李 四 的 、 受 雇 于 北京 某 软件 公司 的 员工 
就 是 雇员 类 的 一 个 对 象 。 

综 上 所 述 ， 可 以 归纳 一 下 类 和 对 象 的 关系 : 类 是 包含 属性 〈 变 量 ) 和 函数 〈 方 法 ， 也 
可 称 为 类 的 行为 ) 的 集合 。 就 像 一 张 建 筑 工程 的 蓝图 一 样 ， 类 本 身 不 能 做 任何 事情 ， 它 只 
是 定义 了 一 个 对 象 所 具有 的 属性 和 方法 ， 属 性 用 于 描述 对 象 ， 而 方法 用 于 定义 对 象 的 行为 ， 
即 对 象 能 做 什么 或 被 做 什么 。 如 图 9-1 所 示 描 述 的 是 汽车 类 ， 它 定义 了 汽车 的 所 有 者 
($owner) 和 颜色 〈$color) 两 个 属性 ， 以 及 显示 汽车 外 观 的 方法 (showcar0) 。 如 果 将 变 
量 $owner 和 $color 分 别 赋予 具体 的 数据 ， 则 会 得 到 相应 的 一 个 汽车 对 象 。 


类 : car 
(变量 /属性 ) 
Var $Sowner 


Var $color 


(函数 方法 /行为 ) 
function showcar0 
‘ 

} 


图 9-1 汽车 类 示意 图 
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9.2 使 用 类 


正如 前 文 所 述 ， 类 是 模板 ， 是 用 于 定义 类 的 属性 和 方法 的 。 下 面 介绍 如 何在 PHP 程序 
中 定义 一 个 类 和 实例 化 一 个 类 ， 以 及 类 成 员 、 类 的 继承 等 相关 知识 。 


9.2.1 定义 类 和 类 的 实例 化 
类 是 面向 对 象 程序 设计 的 核心 ， 它 是 一 种 数据 类 型 。 类 由 变量 和 函数 组 成 ， 在 类 中 ， 


变量 称 为 属性 或 成 员 变 量 ， 函 数 称 为 方法 。 创 建 类 时 ， 要 用 到 关键 字 class， 在 后 面 跟 类 的 
名 称 ， 然 后 用 一 对 大 括号 将 类 的 具体 定义 内 容 括 起 来 ， 其 定义 的 语法 格式 如 下 : 


class classname /定义 类 名 
{ 
var $property[= value];… // 定 义 类 的 属性 
function functionname($args) /定义 类 的 方法 
方法 的 实现 程序 代码 
} 
} 


在 类 中 ， 使 用 关键 字 var 来 声明 变量 ， 即 类 的 属性 ;使 用 关键 字 function 来 定义 函数 ， 
即 类 的 方法 。 例 如 ， 以 下 程序 定义 了 一 个 简单 的 类 a。 


classa 
{ 
var $a; 
function fun($b) 
。 echo "hello world"; 
1 
| 


在 声明 一 个 类 后 ， 类 只 存在 于 文件 中 ， 程 序 不 能 直接 调用 。 需 要 创建 一 个 对 象 后 程序 
才能 使 用 。 就 像 一 张 刚 设计 好 的 桥梁 图 纸 ， 桥 的 外 观 和 相关 工程 参数 只 是 显示 在 图 纸 上 ， 
但 还 不 是 真实 的 桥梁 ， 将 桥 的 蓝图 交 给 负责 施工 的 工程 队 ， 就 可 以 建造 一 座 甚至 多 座 真 实 
的 桥梁 了 ， 工 程 队 施工 建造 桥梁 的 过 程 就 相当 于 下 面 即 将 讲述 的 类 的 实例 化 过 程 。 

在 PHP 中 要 利用 保留 关键 字 new 来 对 一 个 对 象 实例 化 ， 即 创建 一 个 对 象 ， 在 new 关 
键 字 后 面 需要 指定 实例 化 的 类 名 ， 而 用 特殊 变量 $this 来 引用 这 个 新 建 的 对 象 ， 基 于 同一 个 
类 创建 的 不 同 对 象 都 有 相同 的 属性 和 方法 , 但 每 个 属性 具体 的 赋值 是 不 同 的 , 如 汽车 类 car， 
如 果 有 一 辆 实际 的 汽车 ， 其 颜色 (color) 属性 是 红色 ， 而 其 他 不 同 的 汽车 颜色 〈color) 属 
性 可 以 是 白色 、 蓝 色 、 黑 色 等 。 例 如 ， 下 列 程序 定义 一 个 Ctest 类 ， 并 经 实例 化 后 得 到 了 对 
象 $objt。 
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出 。 例 如 ， 


<?php 
class Ctest /定义 一 个 类 Ctest 
上 var $stunumber:; /声明 一 个 属性 
function add($numben) /声明 一 个 方法 
S$this->stunumber=$ number: // 使 用 S$this 引用 内 部 的 属性 
echo $this->stunumber; 
} 
i 
S$objt=new Ctest; // 创 建 Ctest 类 的 一 个 对 象 $objt 
S$objt-> add(12) /调用 类 中 定义 的 方法 
?> 


9.2.2 显示 对 象 的 信息 


可 以 利用 print_r0 函 数 来 显示 对 和 象 的 详细 信息 , 在 显示 对 象 信息 时 , 将 以 数组 的 形式 输 


<?php 
class empolyee 
4 
var $number; 
var $name; 
var $sex; 
var $age; 
function show() 
{ 
echo $this->number; 
echo $this->name; 
echo $this->sex; 
echo $this->age; 
} 
) 
$zhangsan=new empolyee(); 
$zhangsan->number='081101"; 
$zhangsan->name=' 张 三 '; 
$zhangsan->sex=' 男 '; 
$zhangsan->age=21; 
Slisi=new empolyee(); 
Slisi->number='081102"”; 
Slisi->name=' 李 四 '; 
S$lisi->sex=' 女 '; 
Slisi->age=20; 
echo "第 一 个 对 象 的 信息 :“; 


print_r($zhangsan); 


echo "<br/>"." 第 二 个 对 象 的 信息 : 


下 面 这 个 程序 ， 首 先是 定义 了 一 个 类 ， 然 后 创建 了 基于 该 类 的 两 个 实例 ， 最 后 
用 print_r0 函 数 分 别 输出 这 两 个 类 的 信息 。 


/实例 化 第 一 对 象 


/实例 化 第 二 对 象 


// 输 出 第 一 对 象 的 信息 
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print_r(Slisi); // 输 出 第 二 对 象 的 信息 


i 
本 程序 运行 后 的 结果 如 图 9-2 所 示 。 
/人 对象 信 息 的 输出 - Windows Internet Erplerer 


GO lo lx se 


」 文件 四 ”编辑 于 ) 查看 Y) 收藏 天 () 工具 I) 帮助 0) 


ecalhest/ phpbookso -= 


第 一 个 对 象 的 信息 ，empolyee Object ( [number] => 081101 [name] => 


张 三 [sex] => 男 [age] => 21 ) 
第 二 个 对 象 的 信息 ，empolyee Object ( [nunber] => 081102 [name] => 
李 四 [sex] => 女 [age] => 20 ) 


| 


[Sh-[Rio - 


CT 
图 9-2 ”对 象 信息 的 显示 


厂 重 Intermet 


9.2.3 ”类 成 员 和 作用 域 


明 ， 
方法 


这 里 说 的 类 成 员 指 的 就 是 类 的 属性 。 在 PHP 4 中 ， 类 的 属性 必须 使 用 关键 字 var 来 声 


而 在 PHP 5 中 ， 引 入 了 访问 修饰 符 public、private 和 protected。 它 们 可 以 控制 属性 和 

的 作用 域 ， 通 常 放 置 在 属性 和 方法 的 声明 之 前 。 

口 public: 声明 为 公用 的 属性 和 方法 。 若 一 个 属性 或 方法 被 声明 为 public， 则 可 以 在 
类 的 外 部 或 内 部 访问 它们 。public 是 默认 选项 ， 如 果 没有 为 一 个 属性 或 方法 指定 
修饰 符 ， 那 么 它 将 是 public。 

口 ”private: 声明 为 私有 的 属性 和 方法 。 若 一 个 属性 或 方法 被 声明 为 private， 则 只 可 
以 在 类 的 内 部 进行 访问 。 私 有 的 属性 和 方法 将 不 会 被 继承 。 

口 ”protected: 声明 为 被 保护 的 属性 和 方法 。 若 一 个 属性 或 方法 被 声明 为 protected， 
只 可 以 在 类 的 内 部 和 子 类 的 内 部 进行 访问 。 

例如 : 

<?php 

class student /| 声明 一 个 类 

: public $num; 
protected $name; 
private S$telphone; 
public function Stuinfo() 
echo "how are you"; 

} 


$object=new student; 
S$object->num="07121014"; 
echo $object->num; 
$object->Stuinfo(); 
S$object->telphone="84565"; 
?> 


// 创 建 一 个 对 象 Sobject 
// 输 出 "07121014" 


// 输 出 " how are you " 
// 出 错 , 访问 权限 不 够 , telphone 只 能 在 student 类 内 部 被 访问 
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9.2.4 构造 函数 与 析 构 函数 


构造 函数 是 类 中 的 一 个 特殊 函数 ， 当 用 new 来 创建 类 的 对 象 时 会 自动 执行 该 函数 。 如 
果 在 声明 一 个 类 时 同时 声明 了 构造 函数 ， 则 会 在 每 次 创建 该 类 的 对 象 时 自动 调用 此 函数 ， 


因此 非常 适合 在 使 用 对 象 之 前 完成 一 些 初始 化 工作 。 

在 PHP 4 中 ， 在 类 的 内 部 与 类 同名 的 函数 都 被 认为 是 构造 函数 。 而 在 PHP 5 中 ， 构 造 
函数 的 名 称 为 construct (注意 ， 在 construct 前 面 是 两 条 连 着 的 下 划 线 ) 。 如 果 一 个 类 同 
时 拥有 __construct 构造 函数 和 与 类 名 相同 的 函数 ，PHP 5 将 把 _construct 看 作 是 构造 函数 。 
构造 函数 可 以 带 参数 ， 也 可 以 不 带 参 数 。 例 如 ， 下 面 这 个 程序 实现 的 是 九 九 乘法 表 ， 其 程序 


代码 如 下 : 

<?php 

class table 

{ 
public $x; // 乘 法 表 的 维 数 
function __construct() /构造 函数 出 示 化 乘法 表 的 维 数 
{ 

Sthis->x=9; 

} 


function print_table() 


for ($i=1;$i<=$this->x;$i++) 
for ($j=1;$j<=$i,$j++) 


echo $j."*".$i."&nbsp;"; 


echo "<br>"; 
} 
上 
} 
Stable1=new table; // 在 此 处 创建 一 个 对 象 ， 同 时 执行 构造 函数 
Stable1->print_table(); /打印 九 九 乘法 表 


?> 


类 的 析 构 函数 的 名 称 是 _destruct， 如 果 在 类 中 声明 了 _ destruct 函数 ，PHP 在 对 象 不 
再 需要 时 会 调用 析 构 函数 将 对 象 从 内 存 中 销毁 。 例 如 在 销毁 某 对 象 时 将 处 理 好 的 某 些 数据 
一 并 写 进 数据 库 ， 这 时 可 以 考虑 使 用 析 构 函数 来 完成 。 在 析 构 完成 前 ， 这 些 对 象 属性 仍然 
存在 ， 但 只 能 进行 内 部 访问 ， 因 此 ， 析 构 函 数 可 以 做 与 对 象 有 关 的 任何 善后 工作 。 总 之 ， 


析 构 函数 


并 不 仅仅 是 为 了 把 对 象 自身 的 内 存 释放 掉 ， 它 还 能 够 在 用 户 需 要 额外 释放 某 些 内 


存 时 ， 告 诉 PHP 需要 释放 的 内 存在 哪里 ， 并 进而 释放 掉 这 些 内 存 ， 以 节省 服务 器 资源 。 例 


如 ， 下 面 


class 


{ 
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rd_file 
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public S$file; 
function __construct() 


Sthis->file = fopen('‘path', 'a’); 1/ 打开 文 件 
} 
function _ destruct() 


fclose($this->file); // 关 闭 文件 


9.2.5 继承 


现实 生活 中 ， 子 女 可 以 继承 父母 的 财产 。 在 PHP 程序 中 ， 类 也 可 以 从 父 类 中 继承 有 关 
属性 和 方法 的 定义 。 在 面向 对 象 的 程序 设计 中 ， 可 借助 于 “继承 ”这 一 重要 机 制 扩充 某 个 
类 的 定义 ， 即 一 个 新 类 可 以 通过 对 已 有 的 类 进行 修改 或 扩充 来 满足 新 类 的 需求 。 新 类 通过 
继承 来 共享 已 有 类 的 行为 ， 而 自己 还 可 以 修改 或 额外 添加 行为 。 因 此 ， 可 以 说 继承 的 本 质 
特征 是 行为 共享 。 

继承 要 求 至 少 有 一 个 现存 的 类 ， 它 将 作为 父 类 被 继承 。 新 建 的 子 类 用 关键 字 extends 
声明 ， 新 创建 的 类 被 称 为 已 有 类 的 子 类 ， 已 有 类 称 为 父 类 ， 又 叫 基 类 。PHP 不 支持 多 继承 ， 
所 以 一 个 子 类 只 能 继承 一 个 父 类 。 另 外 ， 继 承 是 单方 向 的 ， 即 子 类 可 以 从 父 类 中 继承 特性 ， 
但 父 类 却 无 法 从 子 类 中 继承 特性 。 例 如 ， 有 以 下 两 个 类 的 定义 。 

<?php 

class class A // 定 义 父 类 class_A 


{ 
public $str1; 
private $str2="this is string2"; 
protected $str3=" this is string3"; 
public function a_fun() 


{ 
Sthis->a_str1= " this is string1"; 
b 
1 
class class_B extends class_A // 定 义 子 类 class_B， 继 承 于 父 类 class_A 
public $b_str; // 子 类 中 定义 的 属性 ， 相 当 于 是 在 父 类 基础 之 上 增加 一 个 额外 属性 
public function b_fun() 
{ 
parent::a_fun(); // 子 类 访问 父 类 的 方法 
echo S$this->str1; // 子 类 中 访问 父 类 的 public 属性 
Sthis->str3="str3"; // 子 类 中 访问 父 类 的 protected 属性 
} 
1 
$b=new class_B; // 创 建 对 象 $b 
$b->a_fun(); // 调 用 class_A 类 的 a_fun() 方 法 
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echo $b->str1; /输出 " this is string1" 
$b->b_fun(); /访问 class_B 类 的 方法 
?> 


创建 新 的 子 类 时 ， 如 果 没 有 自己 的 构造 函数 ， 那 么 子 类 在 实例 化 时 会 自动 调用 其 父 类 
的 构造 函数 。 如 果子 类 中 有 自己 的 构造 函数 ， 则 执行 自己 的 构造 函数 。 在 子 类 中 调用 父 类 
的 方法 ， 除 了 使 用 “S$this->” 外 ， 还 可 以 使 用 parent 关键 字 加 范围 解析 符 ， 如 
“parent::functionname()”。 为 了 能 明确 在 调用 时 调用 的 是 子 类 方法 还 是 父 类 方法 ， 建 议 使 
用 后 一 种 写法 。 而 对 于 父 类 的 属性 ， 在 子 类 中 只 能 使 用 “Sthis->” 来 访问 ， 因 为 在 PHP 中 ， 
属性 是 不 区 分 是 父 类 还 是 子 类 的 。 

另外 ， 继 承 可 以 是 多 重 的 ， 也 就 是 说 ， 类 B 继承 了 类 A， 类 C 又 继承 了 类 B， 那 么 类 
C 也 就 继承 了 类 B 和 类 A 的 所 有 属性 和 方法 。 


9.3 PHP 的 对 象 特 性 


PHP 5 为 面向 对 象 编程 提供 了 一 些 新 的 特性 。 下 面 介绍 其 中 非常 重要 的 儿 种 。 至 于 其 
他 的 特性 及 其 内 容 ， 读 者 可 以 参阅 有 关 参 考 书籍 。 


9.3.1 final 类 和 方法 


PHP 5 引入 了 final 关键 字 ， 在 声明 类 时 使 用 这 个 关键 字 ， 将 使 这 个 类 不 能 被 继承 。 被 
声明 为 final 的 方法 可 以 在 子 类 中 使 用 ， 但 不 能 被 覆盖 。 假 设 下 列 代码 中 使 用 final 关键 字 
定义 了 一 个 类 A。 

final classfirst 


{ 


} 


如 果 类 classsecond 尝试 继承 类 A， 将 会 提示 “Fatal error: Class B may not inherit from 
final class (A)” 错 误 信 息 。 再 如 ， 设 计 一 个 Math 类 ， 该 类 主要 完成 一 些 数学 运算 ， 这 些 计 
算 方法 一 般 来 说 没 必 要 修改 ， 也 没 必要 被 继承 ， 因 此 可 将 该 类 设置 成 final 类 ， 具 体 程序 代 
码 如 下 : 


全 过 


<? 
final class Math // 声 明 一 个 final 类 Math 
public static $pi = 3.14; 
public function _toString() 
{ 
return "this is Math class。 "; 
i 
} 
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$math = new Math(); 
echo $math; 
class SuperMath extends Math // 声 明 一 个 子 类 SuperMath， 执 行 时 会 出 错 ，final 类 不 能 被 继承 


站 


?> 


9.3.2 


静态 成 员 是 PHP 5 中 新 增 的 特性 ， 指 不 需要 对 象 实例 就 能 够 使 用 的 属性 或 方法 。 静 态 


成 员 是 一 种 类 变量 ， 可 以 把 它 看 成 属于 整个 类 而 不 是 类 的 某 个 实例 。 静 态 成 员 只 保留 一 个 


变量 值 ， 


而 这 个 变量 值 对 所 有 的 实例 都 是 有 效 的 ， 即 所 有 的 实例 都 共享 这 个 成 员 。 访 问 静 


态 属 性 和 方法 时 ， 需 要 使 用 到 范围 解析 符 “::”， 书 写 格式 如 下 。 


口 
口 


访问 静态 属性 : classname::$attribute; 
访问 静态 方法 : classname::Cfunction([$args,…]); 


例如 ， 下 面 这 个 程序 : 


<?php 
class Cteacher 


{ 
public $num="jery"; 
public static $name=""; 
public static function setname($name) 
{ 
Cteacher::$name=$name; 
public static function getname() 
1 
echo Cteacher:$name; 
} 
} 
Cteacher::setname("smartbean"); // 访 问 setname() 方 法 
Cteacher::getname(); // 输 出 smartbean 
echo Cteacher:$name; /输出 smartbean 
?> 
9.3.3 ”克隆 对 象 


PHP 可 以 使 用 clone 关键 字 建 立 一 个 与 原 对 象 拥有 相同 属性 和 方法 的 对 象 ， 这 种 方法 
适用 于 在 一 个 类 的 基础 上 实例 化 两 个 类 似 对 象 的 情况 。 克 降 对 象 的 语法 格式 如 下 ; 
$new_obj=clone $old_obj; 


其 


ph，S$new_obj 是 新 的 对 象 名 ，$old_obj 是 要 克隆 的 对 象 名 。 


克隆 后 的 对 象 拥有 被 克隆 对 象 的 全 部 属性 ， 如 果 需 要 改变 这 些 属性 ， 可 以 使 用 PHP 提 
供 的 方法 _clone。 该 方法 在 克隆 一 个 对 象 时 将 自动 被 调用 ， 类 似 于 _construct 和 destruct 
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方法 。 例 如 ， 以 下 程序 : 


<?php 
class classparent 


public $number=2; 
public function clone() 
{ 
Sthis->number=$this->number +1; 
中 
1 
$cls1=new classparent; 
$cls2=clone $cls1; 


echo $cls1->number."<br/>"; // 输 出 2 
echo $cls2->number; /| 输出 3 
We 


蛙 序 的 运行 结果 如 图 9-3 所 示 。 


查看 收藏 夫 (8) 工具 CT 帮助 0 


图 9-3 克隆 对 象 


9.3.4 ”方法 重 载 


数 : 


方法 重 载 是 类 多 态 性 的 一 种 实现 ， 是 指 一 个 标识 符 被 用 作 多 个 函数 名 且 能 够 通过 函数 
的 参数 个 数 或 参数 类 型 将 这 些 同名 的 函数 区 分 开 来 ， 调 用 不 会 发 生 混淆 。 这 样 做 的 主要 好 
处 就 是 ， 不 用 为 了 不 同 的 参数 类 型 或 参数 个 数 而 写 多 个 函数 。 方 法 重 载 情况 下 ， 虽 然 多 个 
函数 使 用 同一 个 名 字 ， 但 由 于 参数 的 个 数 和 数据 类 型 不 同 ， 因 此 根据 参数 表 可 以 自动 调用 
对 应 的 函数 。PHP 5 中 , 方法 _call0 可 以 用 于 实现 方法 的 重 载 。_call 方法 必须 要 有 两 个 参 


第 一 个 参数 包含 被 调用 的 方法 名 称 ， 第 二 个 参数 包含 传递 给 该 方法 的 参数 数组 。 当 类 
中 相应 的 方法 被 访问 时 ，__call 方法 才 被 调用 。 例 如 ， 下 列 程序 代码 : 
<?php 
class C_call 
t 
function getarray($a) 
print_r($a); 
上 
function getstr($str) 
{ 
echo $str; 
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寺 
function __call($method, $array) 


攻 
if($method=='show) 


if(is_array($array[0])) 
$this->getarray($array[0]); 
else 
Sthis->getstr($array[0]); 


} 


} 

$obj=new C_call; // 类 的 实例 化 
$obj->show(array(1,2,3)); // 输 出 :Array ([0] => 1 [1] => 2 [2] => 3) 
$obj->show('string'); // 输 出 :'string 

?> 


程序 的 运行 结果 如 图 9-4 所 示 。 


上 文件 四 。 绩 得 加 查看 册 ， 收 基 天 0) 工具 (I) 帮助 0 
这 收 主 天 。 确 方法 重 载 


Array ( [0] => 1 [1] => 2 [2] => 3 ) 
String 


芽 厂 厂 厂 厂 厂 厂 夺 Bes 


图 9-4 方法 重 载 


9.4 ”案例 训 析 : 一 个 课程 管理 类 及 其 对 象 的 实现 


在 高 等 学 校 中 ， 由 于 专业 众多 ， 开 设 的 课程 也 非常 多 ， 如 何 有 效 管理 大 量 的 课程 是 每 
所 高 校 都 不 能 回避 的 问题 。 但 是 ， 课 程 虽然 众多 ， 这 些 课程 之 间 却 存在 着 很 多 共性 ， 因 此 
可 以 将 课程 定义 为 一 个 类 ， 以 此 来 进行 面向 对 象 编程 ， 实 现 对 课程 的 信息 化 管理 。 下 面 举 
一 个 简单 例子 ， 希 望 对 读者 有 抛砖引玉 之 效 。 


9.4.1 程序 功能 介绍 


首先 应 对 所 有 课程 的 共性 进行 抽象 ， 以 便 在 编程 时 能 用 程序 代码 实现 类 的 定义 。 例 如 ， 
所 有 课程 都 应 具有 课程 编号 、 课 程 名 称 、 课 程 类 别 、 任 课 教 师 、 课 时 数 等 公共 的 属性 ， 然 
后 还 要 定义 一 个 该 类 的 行为 即 方法 ， 用 来 显示 某 课程 对 象 的 具体 内 容 。 用 PHP 来 定义 该 课 
程 类 的 程序 代码 如 下 : 

class student 

{ 


private $number; 
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private $name; 


private $type; 

private S$teacher; 

private $ksshu; 

function show($KH,$KM,$LB,$teacperson,$kss) ”// 定 义 方法 ， 用 于 显示 对 象 内 容 
上 


S$this->number=$KH; 
S$this->name=$KM; 

Sthis->type=$LB; 
Sthis->teacher=$teacperson; 
Sthis->ksshu=$kss; 

echo "课程 编号 : ".$this->number."<br>"; 
echo "课程 名 称 :".$this->name."<br>"; 
echo "课程 类 别 : ".$this->type."<br>"; 
echo "教师 姓名 : ".$this->teacher."<br>"; 
echo "讲课 时 数 :".$this->ksshu."<br>"; 


} 
本 程序 要 求 客户 端 用 户 通 过 一 个 Web 页 面 表单 来 实例 化 课程 类 ， 提交 表单 之 后 ,程序 
将 在 服务 器 端 产生 某 门 课程 的 一 个 具体 课程 对 象 。 


9.4.2 程序 代码 分 析 


基于 前 面 对 该 课程 类 的 属性 和 方法 的 抽象 以 及 对 程序 功能 的 描述 ， 可 编写 如 下 程序 
代码 : 


<html> 
<head> 
<title> 课 程 管理 类 </title> 
</head> 
<body> 
<form method="post"> 
<h5> 初 始 化 课程 类 的 属性 :<h5> 
课程 编号 : <input type="text" name="number"><br> 
课程 名 称 : <input type="text" name="name"><br> 
任课 教师 : <input type="text" name="tcname"><br> 
课 时 数 : <input type="text" name="kscount"><br> 
课程 类 别 : <input type="radio" name="type" value=" 公 共 基 础 " checked="checked"> 公 共 基 础 
<input type="radio" name="type" value=" 专 业 基 础 "> 专业 基础 <br> 
<input type="radio" name="type" value=" 专 业 选 修 "> 专业 选修 <br> 
<input type="submit" name="ok" value=" 显 示 实 例 化 后 的 对 象 "> 
</form> 
<?php 
class student 
{ 
private $number; 
private $name; 
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private $type; 

private S$teacher; 

private $ksshu; 

function show($KH,$KM,$LB,$teacperson,$kss) 
S$this->number=$KH:; 
Sthis->name=$KM; 
Sthis->type=$LB; 
Sthis->teacher=$teacperson; 
Sthis->ksshu=$kss; 
echo "课程 编号 :".$this->number."<br>"; 
echo "课程 名 称 :".$this->name."<br>"; 
echo "课程 类 别 :".$this->type."<br>"; 
echo "教师 姓名 : ".$this->teacher."<br>"; 
echo "讲课 时 数 :".$this->ksshu."<br>"; 


} 
D 
if(isset($_POST['ok'")) 
{ 
$KH=$_POST[number]; 
$KM=$_POST[name']; 
$LB=$_POST['type']; 
Steacperson=$_POST[tcname']; 
$kss=$_POST[kscount]; 
$stu=new student; 
echo "实例 化 课程 类 后 得 到 的 一 个 对 象 为 "."<br/>"; 
$stu->show($KH,$KM,$LB,$teacperson,$kss); 
电 
</body> 
</html> 


程序 的 运行 结果 如 图 9-5 所 示 。 


管理 基 -Windows Interaet Replorer 


GSO- Tocalhost w NIE 


本 文件 中 钥 民 名 喜 看 咏 路基 天 工具 fT) 帮助 0 
语 收 基 天 。 大 课程 和 理 失 sl 


初始 化 课程 类 的 属性 : 


课程 编号 。 [55011172451 
课程 名 称 。 民 二 程序 设计 至 础 
任课 教师 。 持 某 某 
课 时 数 。 [54 
课程 类 别 : 个 公共 基础 全 专业 基础 
个 专业 连 俯 

蚂 示 实 例 化 后 的 对 象 


实例 化 深 程 类 后 得 到 的 一 个 对 锡 为 
课程 编号 。C501114451 


@ rt 


图 9-5 课程 管理 类 及 对 象 的 实现 


ERY 
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9.5 本 章 小 结 


本 章 介绍 了 如 何在 PHP 中 实现 面向 对 象 编程 。 通 过 学 习 ， 读 者 应 熟悉 面向 对 象 编程 中 
的 常用 术语 和 一 些 基本 编程 技巧 。 面 向 对 象 编程 技术 一 个 最 大 的 优势 是 它 会 尽量 模拟 真实 
的 环境 ， 因 此 能 更 直观 、 科 学 、 合 理 地 实现 用 户 想 要 的 应 用 。 面 向 对 象 的 编程 思想 大 大 解 
放 了 程序 员 ， 使 程序 员 的 工作 效率 得 以 大 大 提高 。 同 时 ， 利 用 面向 对 象 编程 技术 研制 出 来 
的 软件 具有 很 强 的 灵活 性 和 可 扩展 性 等 优点 。 


9.6 练习 题 


. 在 PHP 中 如 何 定义 类 及 类 的 成 员 ? 

如 何 创建 基于 类 的 一 个 对 象 ? 

如 何 定义 私有 、 公 共和 受 保护 的 属性 ? 怎样 实现 类 的 继承 ? 
. 简 述 构造 函数 和 析 构 函数 的 功能 ， 并 描述 其 语法 结构 。 


人 mi 一 


97 上 机 实战 


请 用 面向 对 象 编程 技术 在 PHP 程序 中 创建 一 个 学 生 类 ,在 类 中 要 求 定义 的 属性 有 学 号 、 
姓名 、 性 别 、 班 级 编号 、 专 业 、 选 修 课 程 课 号 、 课 程 名 称 和 考试 成 绩 。 然 后 编写 两 个 方法 : 
selectcourse() 方 法 用 来 实现 学 生 选课 操作 ;showsocre0) 方 法 用 来 显示 所 选课 程 的 考试 成 绩 。 
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知识 点 : 


Dreamweaver CS4 简介 

利用 Dreamweaver CS4 建立 PHP 网 站 站 点 

Dreamweaver CS4 中 怎样 连接 MySQL 数据 库 

创建 记录 集 与 记录 集 导 航 条 

常见 的 MySQL 数据 库 操作 在 Dreamweaver CS4 中 的 实现 


本 章 导读 : 


PHP 动态 网 页 是 一 种 无 格式 的 纯 文本 文件 , 利用 Windows 记事 本 等 一 般 的 文本 编辑 器 
即 可 编写 PHP 动态 网 页 程序 。 但 如 果 要 创建 和 维护 一 个 大 型 、 复 杂 的 PHP 动态 网 站 ， 普 
通 文 本 编辑 器 就 显得 力不从心 。 应 用 Dreamweaver CS4 可 以 弥补 普通 文本 编辑 器 工作 效率 
低下 的 缺点 ， 它 提供 了 一 组 与 MySQL 数据 库 访问 有 关 的 服务 器 行为 ， 如 创建 记录 集 、 创 
建 记录 集 导 航 条 、 插 入 记录 、 人 删除 记录 以 及 更 新 记录 等 ， 可 以 快速 生成 PHP 数据 库 程序 。 


加 网 网罗 多 


10.1 _ Dreamweaver CS4 概述 


Dreamweaver 是 一 款 集 网 页 设计 和 网 站 管理 于 一 身 的 可 视 化 网 页 开发 软件 , 其 最 新 版 
本 是 Dreamweaver CS4。 Dreamweaver CS4 采用 多 种 先进 技术 , 提供 了 强大 的 可 视 化 工具 、 
应 用 开发 功能 和 代码 编辑 支持 ， 使 开发 人 员 能 快速 高 效 地 设计 、 开 发 和 维护 跨越 平台 
制 及 跨越 浏览 器 限制 的 网 站 和 应 用 程序 。Dreamweaver CS4 和 之 前 的 版 本 相 比 ， 其 界面 几 
乎 是 做 了 一 次 脱胎 换 骨 的 改进 ， 可 以 看 到 更 多 的 设计 元 素 ， 使 开发 人 员 可 以 快捷 地 创建 
出 代码 规范 的 应 用 程序 。Dreamweaver CS4 (为 叙述 方便 ， 以 下 简称 Dreamweaver 或 DW) 
应 用 程序 的 操作 环境 包括 菜单 栏 、 工 具 栏 、 文 档 窗口 、 属 性 面板 、 面 板 组 和 下 拉 按 钮 等 
几 个 部 分 ， 如 图 10-1 所 示 。 


10.2 ”利用 Dreamweaver 建立 PHP 动态 网 站 站 点 


创建 站 点 的 目的 在 于 将 本 地 文件 与 Dreamweaver 之 间 建 立 联系 ， 使 设计 人 员 可 以 通过 
Dreamweaver 管理 站 点 文件 。 


PHP Web 开发 实用 教程 


“实时 视图 "按钮 


下 拉 按钮 莱 单 栏 
om or pe 
文件 加 。 久 模 和 /查看 竺 入 


命中 站 训 回 证) 帮 动 0 
三。 和: 丫 生 4 村 


图 10-1 Dreamweaver CS4 界面 


10.2.1 站 点 的 建立 


了 静态 网 站 相 比 ，PHP 动态 网 站 的 建立 步骤 基本 相同 ， 只 不 过 后 者 要 使 用 一 种 被 称 为 
PHP MySQL 的 服务 器 技术 。 下 面 介绍 在 Dreamweaver 中 如 何 创建 一 个 基于 PHP+MySQL 
服务 器 模型 的 动态 站 点 ， 其 操作 步骤 如 下 : 

(1) 启动 Dreamweaver， 选 择 “ 站 点 ”一 “新 建站 点 ”命令 ， 弹 出 如 图 10-2 所 示 的 
站 点 定义 对 话 框 。 


ireamewwr 中 站 后 是 六 从 和 立 隆 于 的 介 合 ， 它 对 可 于 服务 器 上 Wab 站 性。 


纸 打 前 为 你 的 让 点 起 什么 名 字 ? 
pr 

示 便 : site 

妮 的 让 点 了 HTP 志 直 IEL) 是 什么 了 


Jieeawesl 


图 10-2 站 点 定义 对 话 框 


(2) 选择 “基本 ”选项 卡 ， 为 新 站 点 输入 一 个 名 称 ， 在 此 输入 “phpstudy”， 并 指定 
站 点 的 HTTP 地 址 ， 此 处 输入 “http://localhost”， 然后 单 击 “ 下 一 步 ” 按 钮 ， 弹 出 如 图 10-3 
所 示 的 选择 服务 器 技术 的 对 话 框 。 
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(3) 选中 “是 ， 我 想 使 用 服务 器 技术 ” 单 选 按钮 ， 并 在 “ 哪 种 服务 器 技术 ? ”下 拉 列 
表 框 中 选择 PHP MySQL， 然 后 单 击 “ 下 一 步 ” 按 钮 ， 弹 出 如 图 10-4 所 示 的 界面 。 


bamstaar 的 站 点 定义 为 
|i | 


坎 是 本 条 和 全 用 服务 加 技术 ， 扣 ruiyust on， ar ET、AGT、J5F 或 PE? 
人 百 , 我 下 起 全 用 服务 加 技 术 。 D) 
人 党 而 放 才 0 


器 种 报 务 器 技术 ? 所) 
[nr meat 


图 10-3 选择 服务 器 技术 的 对 话 框 图 10-4 选择 网 页 文件 的 处 理 方式 


(4) 选中 “在 本 地 进行 编辑 和 测试 〈 我 的 测试 服务 器 是 这 台 计 算 机 ) ” 单 选 按钮 ， 在 
“您 将 把 文件 存储 在 计算 机 上 的 什么 位 置 ? "文本 框 中 输入 Apache 服务 器 的 文档 根 目录 或 
某 个 虚拟 目录 的 路 径 ， 也 可 通过 单 击 文 本 框 右 侧 的 加 按钮 来 选择 此 路 径 ， 在 此 选择 的 是 
Apache 服务 器 的 默认 文档 根 目 录 ， 然 后 单 击 “ 下 一 步 ”按钮 。 

(5) Dreamweaver 将 弹出 测试 服务 器 的 对 话 框 ， 此 时 要 输入 站 点 根 目录 的 URL 地 址 ， 
然后 单 击 “ 测 试 URL” 按 钮 ， 如 果 测 试 成 功 ， 将 弹出 “URL 前 绥 测 试 已 成 功 。” 的 消息 提 
示 框 ， 单 击 “ 确 定 ”按钮 以 关闭 该 提示 框 ， 如 图 10-5 所 示 ， 然 后 单 击 “ 下 一 步 ”按钮 。 

us |iet | a 
站 点 定义 


Dr sans ever 合用 ITTE 《 如 同 浏 必 基 与 人 的 测 江 限 务 器 注 行 酒 信 ， 因 比 它 天 要 4 着 
7 We 


修订 该 全 用 什么 RL 于 浏 客 寺 点 的 横 目 录 ? 人 
es 


图 10-5 测试 服务 器 的 对 话 框 


(6) 弹出 如 图 10-6 所 示 的 界面 ， 根 据 具体 情况 可 做 出 如 下 选择 。 

口 ”如果 编 辑 完 一 个 文件 后 ， 要 把 该 文件 复制 到 另 一 台 计 算 机 ， 可 选中 “是 的 ， 我 要 
使 用 远程 服务 器 ” 单 选 按钮 。 

口 ” 如 果 不 使 用 远程 服务 器 ， 可 选中 “和 否 ” 单 选 按钮 。 
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在 此 选择 第 二 项 即 “和 否 ” 单 选 按钮 ， 然 后 单 击 “ 下 一 步 ”按钮 。 而 如 果 选 择 第 一 项 ， 
则 还 需 对 连接 远程 服务 器 的 方式 、 远 程 文件 夹 以 及 文件 的 存 回 和 取出 等 选项 进行 设置 。 以 
上 步骤 完成 后 ， 将 弹出 新 建站 点 的 信息 汇总 窗口 ， 如 图 10-7 所 示 。 


hpststy 的 试点 直方 


say 的 请 
[2 


Ne 
产 用 feb 

个 是 的 ， 我 要 使 用 运程 服务 器 台 ) 

“齐名 


个 的 直 点 包 计 以 下 吉本 
本 地 污 自 - 

下 训 冯 称 : plsstaiy 

本 页 : DTreer Fileatgedhe croup lode? htdocs 


运 各 信息- 
这 可 “城村 在 后 冯 砚 此 设 于 - 


ET 
运 渍 文件 天 :Pro am BiltzMesdhe Cro escheathtdees\ 


可 以 使 且 训 丰 迁 本 下 对 疙 下 点 进行 进 一 步 本 得. 


SEC mn | om | 
图 10-6 选择 是 否 使 用 远程 服务 器 图 10-7 选 站 点 设置 信息 汇总 

(7) 单 击 “完成 ”按钮 ，Dreamweaver 将 自动 在 文件 面板 中 打开 该 站 点 ， 如 图 10-8 

所 示 。 此 时 的 站 点 没有 一 个 网 页 文件 ， 是 一 个 空 站 点 ， 可 用 鼠标 右键 单 击 该 站 点 的 文件 夹 

图 标 “[ 号 ”， 在 弹出 的 快捷 菜单 中 选择 “新 建文 件 ”命令 ， 如 图 10-9 所 示 ， 然 后 系统 将 自 


动 创建 名 为 untitled.php 的 网 页 文件 ， 此 时 的 文件 名 还 处 于 高 亮色 状态 ， 提 示 用 户 可 重新 命 
名 该 文件 名 。 


[rhpstuay 下 | 下 地 视图 ” 瑟 
趴 C58 个 沪 名 加 | 加 


@ ”1 个 本 地 项 目 被 选中 ,总 共 日 志 ..- 


图 10-8 ”站 点 文件 面板 图 10-9 新建 文件 快捷 菜单 


10.2.2 在 Dreamweaver 中 创建 MySQL 连接 

正如 第 7 章 所 述 , PHP 提供 了 一 组 MySQL 库 函 数 , 其 中 包括 实现 与 MySQL 数据 库 连 
接 的 函数 MySql connect0。 在 Dreamweaver 中 可 以 使 用 “数据 库 ” 面 板 来 创建 MySQL 数 
据 连接 ， 操 作 方 法 如 下 : 
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(1) 在 Dreamweaver 中 打开 一 个 PHP 网 页 ， 选 择 “ 窗 口 ” 一 “数据 库 ” 命 令 或 者 按 
ShiftrCtrl+F10 组 合 键 ， 打 开 如 图 10-10 所 示 的 “数据 库 ” 面 板 。 
《2 单 击 按钮 ， 选 择 “MySQL 连接 ”命令 ， 如 图 10-11 所 示 。 


的 测试 胆 务 器 站 点 的 测试 服务 器 。 
4 bh 按钮 外 了 建 连 关机 上 9 + 按 钥 包 建 连 


图 10-10 “数据 库 ” 面 板 图 10-11 MySQL 数据 库 连 接 命令 


(3) 在 设置 数据 库 连 接 之 前 ， 应 保证 已 启动 了 MySQL 服务 器 。 在 “MySQL 连接 ” 
对 话 框 中 ， 通 过 设置 如 图 10-12 所 示 的 各 个 选项 ， 为 当前 PHP 动态 网 站 创建 数据 库 连接 ， 
需要 设置 的 内 容 如 下 : 

@ 输入 新 连接 的 名 称 ， 如 constu。 需 提醒 读者 的 是 ， 不 要 在 该 名 称 中 使 用 任何 空格 或 
特殊 字符 。 

@ 在 “MySQL 服务 器 ”文本 框 中 ， 指 定 承载 MySQL 的 计算 机 ， 可 以 输入 IP 地 址 或 
服务 器 名 称 。 若 MySQL 与 PHP 运行 在 同一 台 计 算 机 上 ， 则 可 输入 “localhost” 

@ 输入 MySQL 用 户 名 和 密码 。 

@ 在 “数据 库 ” 文 本 框 中 输入 要 连接 的 数据 库 名 称 ， 也 可 以 单 击 “ 选 取 ” 按 钮 并 从 
MySQL 数据 库 列 表 中 选择 要 连接 的 数据 库 ， 如 图 10-13 所 示 ， 这 里 选择 的 是 student 数据 
库 ， 然 后 单 击 “ 确 定 ” 按 钮 返回 到 “ isin 连接 ”对 话 框 中 。 


图 10-12 “MySQL 连接 ”对 话 框 图 10-13 选择 数据 库 


(4) 单 击 “MySQL 连接 ”对 话 框 中 的 “测试 ”按钮 ， 如 果 Dreamweaver 连接 数据 库 
成 功 ， 则 会 显示 “成 功 创建 连接 脚本 。” 的 提示 信息 框 ， 如 图 10-14 所 示 。 如 图 连接 失败 ， 
用 户 需 检查 服务 器 名 称 、 用 户 名 、 密 码 等 信息 是 否 设置 正确 。 然 后 再 单 击 “MySQL 连接 ” 
对 话 框 中 的 “确定 ”按钮 ， 新 连接 的 数据 库 将 出 现在 “数据 库 ” 面 板 中 ， 如 图 10-15 所 示 ， 
这 个 数据 库 连 接 可 以 在 当前 站 点 的 所 有 PHP 页 面 中 使 用 。 


二 了 工 生 部 定 | 服务 器 行为 | 组 件 


图 10-14 连接 成 功 提示 杠 图 10-15 “数据 库 ” 面 板 中 的 数据 库 
(5) 数据 库 连 接 创建 成 功 后 ， 打 开 Dreamweaver 的 “文件 ”面板 ， 将 在 站 点 根 目录 下 


193 


了 PHP Web 开发 实用 教程 


查看 到 一 个 名 为 Connections 的 文件 夹 , 并 在 该 文件 夹 内 生成 了 一 个 与 新 建 连接 同名 的 PHP 
文件 ， 如 图 10-16 所 示 ， 该 PHP 文件 就 是 数据 库 连接 文件 ， 它 首先 通过 4 个 变量 保存 数据 
库 连 接 参数 ， 包 括 MySQL 服务 器 名 称 、 要 连接 的 数据 库 名 称 、 用 户 名 和 密码 ， 然 后 通过 调 
用 mysql pconnect0 函 数 建立 一 个 永久 连接 ， 其 中 参数 trigger error(mysql] error(,E USER 
ERROR) 用 来 生成 一 个 用 户 级 别 的 错误 、 警 告 信息 ， 此 参数 本 身 也 是 一 个 函数 ， 如 图 10-17 
所 示 。 


K?php 


EM $hostnane_constu = "localhost"; 

$database_constu = 

WW $usernane_constu = 
$password_constu = “ 


4 
$constu = mysql_pconnect ($hostnane_constu, $usernane_constu, 
$password_constu) or trigger_error (nysql_error (),E_USER_ERROR) ; 
?> 


图 10-17 用 于 数据 库 连 接 的 PHP 程序 

为 了 避免 访问 MySQL 数据 库 时 出 现 乱 码 现象 ， 可 以 在 上 述 新 建 的 数据 库 连 接 文件 的 
PHP 程序 代码 末尾 添加 如 下 语句 ， 其 功能 是 将 数据 库 的 字符 集 设 为 简体 中 文 : 

mysql_query ("SET NAMES gb2312") ; 

另外 ， 还 应 将 PHP 网 页 的 字符 集 也 设 为 简体 中 文 ， 方 法 是 通过 设置 位 于 文件 首部 的 
<meta> 标 记 来 实现 ， 其 修改 后 的 代码 如 下 : 

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 

如 果 要 把 新 建 的 网 页 的 字符 集 自 动 设置 为 gb2312, 则 要 在 Dreamweaver 的 首选 参数 中 
对 默认 编码 进行 设置 ， 步 骤 为 : 选择 “编辑 ”一 “首选 参数 ”命令 ， 弹 出 “首选 参数 ”对 
话 框 ， 从 “分 类 ”列表 中 选择 “新 建文 档 ”， 然 后 从 “默认 编码 ”下 拉 列 表 框 中 选择 “ 简 
体 中 文 (GB2312) ”选项 ， 如 图 10-18 所 示 。 
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歌 以 文档 加 ): [irr 了 
默 这 攻 展 名 台 ): | htel 
默 这 文档 关 型 0TD) [om 1.0 Transitional 了 


MR 0) [| 


灰 当 打 开 未 指定 莹 码 的 现 有 文件 时 使 用 


Unieode 标准 化 表单 到 ): | (规范 分 解 ， 后 跟 规范 合成 ) 了 


厂 包括 Wicede 签名 (ou) 人 G) 


灰 按 contrel+N 组 合 键 时 显示 “新 建文 档 ” 对 话 框 g) 


图 10-18 “首选 参数 ”对 话 框 
10.2.3 ”数据 库 连 接 的 管理 与 应 用 
在 Dreamweaver 中 创建 数据 库 连 接 后 , 如 果 要 在 PHP 页 中 引用 已 创建 的 数据 库 连 接 标 


识 符 和 其 他 连接 参数 , 可 以 在 “数据 库 ” 面 板 上 右 击 该 连接 并 从 弹出 的 快捷 菜单 中 选择 “ 插 
入 代码 ”命令 ， 如 图 10-19 所 示 ， 命 令 执 行 完毕 后 将 在 网 页 文件 中 生成 PHP 代码 : 


<?php require_once('Connections/constu.php'); ?> 


了 定 | 服务 器 行为 | 组件 


图 10-19 向 网 页 中 插入 数据 库 连 接 标识 符 

利用 “数据 库 ” 面 板 可 以 对 数据 库 连 接 进 行 管理 ， 主 要 包括 以 下 操作 。 

口 ”编辑 连接 : 右 击 一 个 连接 名 称 并 从 弹出 的 快捷 菜单 中 选择 “编辑 连接 ”命令 ， 然 
后 在 连接 对 话 框 中 修改 除 连 接 名 称 以 外 的 其 他 任何 参数 。 

口 重 制 连 接 : 右 击 一 个 连接 并 从 弹出 的 快捷 菜单 中 选择 “ 重 制 连接 ”命令 ， 然 后 在 
连接 对 话 框 中 修改 任何 连接 参数 ， 包 括 连 接 名 称 。 

口 ”删除 连接 : 右 击 一 个 连接 并 从 弹出 的 快捷 菜单 中 选择 “删除 连接 ”命令 ， 即 可 删 

除 该 数据 库 连 接 ， 或 者 选中 连接 名 称 后 再 单 击 “ 数 据 库 ” 面 板 上 的 局 I 按 钮 也 可 删 

口 “测试 连接 : 右 击 一 个 连接 并 从 弹出 的 快捷 菜单 中 选择 “测试 连接 ”命令 。 如 果 连 
接 成 功 ， 则 会 看 到 “成 功 创建 连接 脚本 ”的 信息 ， 否 则 将 提示 连接 失败 信息 。 
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10.3 ”数据 集 的 创建 与 应 用 


在 第 7 章 ， 介 绍 了 运用 MySql queryO0、MYSql fetch array()、MySql num rows() 等 函 
数 来 实现 在 网 页 中 输出 MySQL 数据 库 的 数据 集合 即 记录 集 ， 在 Dreamweaver 中 同样 可 以 
容易 地 实现 该 功能 。 


10.3.1 利用 Dreamweaver 创建 记录 集 


在 Dreamweaver 中 ， 使 用 简单 记录 集 对 话 框 或 高 级 记录 集 对 话 杠 来 定义 记录 集 ， 而 不 
需要 编写 任何 PHP 代码 。 在 简单 记录 集 对 话 框 中 不 需 编辑 SQL 语句 ， 在 高 级 记录 集 对 话 
框 中 可 以 通过 编写 SQL 语句 来 创建 比较 个 性 化 、 复 杂 的 记录 集 。 

1. 创建 简单 的 记录 集 


如 果 用 户 进行 简单 的 查询 操作 ， 可 以 使 用 Dreamweaver 所 提供 的 简单 记录 集 定 义 对 话 
框 来 定义 记录 集 ， 其 步骤 如 下 : 

(1) 在 “ 绑 定 ” 面 板 中 单 击 天 按钮 ， 如 图 10-20 所 示 ， 选 择 “记录 集 (查询) ”命令 
后 即 可 对 记录 集 进行 相关 设置 。 

(2) 打开 “记录 集 ” 对 话 框 , 在 “名 称 ” 文 本 框 中 输入 用 户 定义 的 记录 集 名 称 , 在 “ 连 
接 ” 下 拉 列 表 框 中 选择 数据 库 连接 名 称 如 constu， 在 “表格 ”下 拉 列 表 框 中 选择 数据 库 连 
接 名 称 所 对 应 的 数据 库 中 的 数据 表 ， 这 里 选择 的 是 stu_person。 在 “ 列 ” 选 项 组 中 选中 “全 
部 ” 单 选 按钮 ， 如 果 有 筛选 和 排序 要 求 ， 还 可 以 在 “筛选 ”及 “排序 ”两 项 中 进行 设置 ， 
如 图 10-21 所 示 。 


数据 库 儿 汶 服务 器 行为 “组件 


图 10-20 选择 “记录 集 (查询 ) ”命令 图 10-21 设置 记录 集 内 容 

(3) 为 了 确认 其 设置 的 正确 性 ， 单 击 “ 测 试 ”按钮 即 可 ， 如 图 10-22 所 示 是 测试 成 功 
后 返回 的 记录 集 数据 ， 然 后 单 击 “ 确 定 ” 按 钮 ， 完 成 记录 集 的 设置 ， 完 成 后 ， 在 “ 绑 定 ” 
面板 的 列表 框 中 显示 建立 的 记录 集 列 表 ， 如 图 10-23 所 示 。 
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测试 SQ 指令 划 | 


id ass id 


SNOSSSRSSSSNNNS 


1 
2 
3 
4 
5 
6 
7 OT632 
a 
9 
10 
1 
12 
13 
14 
15 
16 


图 10-22 ”记录 集 测 试 窗口 图 10-23 “ 绑 定 ”面板 中 的 记录 集 

至 此 ， 简 单 记 录 集 创建 完毕 ， 但 此 时 用 户 看 不 到 直观 的 详细 记录 集 内 容 。 下 面 介绍 在 
Dreamweaver 中 如 何 实现 将 简单 记录 集 显示 到 网 页 上 ， 其 步骤 如 下 : 

(1) 在 站 点 中 新 建 一 个 PHP 网 页 ， 用 于 显示 记录 集 。 

(2) 由 于 新 建 的 数据 库 连 接 在 整个 站 点 的 所 有 网 页 都 有 效 ， 因 此 ， 在 新 建 的 网 页 中 仍 
然 可 用 此 连接 ， 此 时 可 直接 利用 简单 记录 集 创 建 对话 框 定义 一 个 记录 集 ， 方 法 如 10.3.1 小 节 
中 的 “创建 简单 的 记录 集 ” 部 分 所 述 。 

(3) 选择 “插入 ”一 “数据 ”一 “动态 数据 ”一 “动态 表格 ”命令 ， 打 开 “ 动 态 表 格 ” 
对 话 框 ， 然 后 对 以 下 选项 进行 设置 ， 如 图 10-24 所 示 。 


图 10-24 “动态 表格 ”对 话 框 

Q@ 从 “记录 集 ” 下 拉 列 表 框 中 选择 之 前 所 定义 好 的 记录 集 。 

@ 显示 记录 集 的 方式 ， 可 从 “显示 ” 单 选 按钮 组 中 设置 ， 主 要 有 两 种 : 若 要 分 页 显示 
记录 集 ， 可 选中 第 一 个 单 选 按钮 并 在 文本 框 中 设置 每 页 显示 的 记录 数目 ， 如 果 在 一 个 页 面 
上 显示 所 有 记录 ， 则 应 选中 “所 有 记录 ” 单 选 按钮 。 

@@ 根据 实际 需要 ， 对 动态 表格 的 边框 、 单 元 格 边 距 和 单元 格 间距 进行 设置 。 

完成 以 上 设置 后 ， 单 击 “ 确 定 ” 按 钮 ， 此 时 ， 一 个 动态 表格 就 插入 到 当前 网 页 文档 中 ， 
如 图 10-25 所 示 。 


E 下 naae SEX age st_id Class_id 


Recordset!, st id} |fRecordset!, class id} 
图 10-25 插入 到 网 页 文档 中 的 动态 表 


(4) 利用 Dreamweaver 表格 设计 工具 对 表格 属性 进行 设置 ， 以 美化 网 页 外 观 。 
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(5) 上 述 过 程 基本 上 无 须 用 户 编写 PHP 代码， 所 有 代码 都 由 系统 自动 生成 ， 用 户 可 切换 
到 代码 视图 来 查看 生成 的 PHP 代码 ， 然 后 在 浏览 器 中 查看 网 页 运行 效果 ， 如 图 10-26 所 示 。 


/简单 到 玫 蘑 的 获取 一 


站 
让 局 从 和 9 各 | 


学 生 基本 信息 表 


sex | age | st id 


图 10-26 简单 记录 集 在 网 页 中 的 运行 效果 
2. 创建 高 级 记录 集 


简单 记录 集 只 能 从 一 个 表 中 检索 数据 ， 而 且 在 筛选 条 件 和 排序 准则 中 都 只 能 包含 一 个 
字段 ， 如 果 要 实现 多 表 查 询 、 创 建功 能 更 为 强大 的 记录 集 ， 则 应 当 使 用 高 级 记录 集 对 话 框 
来 完成 ， 使 用 高 级 记录 集 对 话 框 创建 数据 集 时 ， 可 以 手动 编写 SQL 语句 ， 也 可 以 使 用 可 视 
化 的 “数据 库 项 ” 树 工具 来 协助 创建 SQL 语句 ， 两 种 方式 都 能 创建 功能 更 强 、 比 较 复 杂 的 
数据 库 查 询 。 创 建 高 级 记录 集 的 步骤 如 下 : 

(1) 在 “ 绑 定 ” 面 板 中 单 击 国 按 钮 后 ， 弹 出 如 图 10-27 所 示 的 “记录 集 ” 对 话 框 ， 单 

(2) 弹出 如 图 10-28 所 示 的 高 级 “记录 集 ” 对 话 框 ， 在 此 进行 相关 设置 。 


图 10-27 “记录 集 ” 对 话 框 图 10-28 高 级 “记录 集 ” 对 话 框 


(3) 在 “名 称 ” 文 本 框 中 定义 数据 集 名 称 ， 在 “连接 ”下 拉 列 表 框 中 选择 用 于 定义 记 
录 集 的 数据 库 连接 ， 在 此 选择 刚刚 创建 的 字符 串 连 接 constu， 如 果 还 未 定义 数据 库 连 接 ， 
可 单 击 右 侧 的 “定义 ”按钮 进行 定义 。 

(4) 根据 实际 需要 ， 在 SQL 文本 框 中 输入 所 需 的 SQL 查询 语句 。 在 此 文本 框 中 输入 
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以 下 语句 以 在 两 个 数据 表 中 实现 相关 信息 的 查询 : 


SELECT Name, NoteContent, personHomepage, users.Name, Password, users. Password FROM 
notecontent, users WHERE notecontent.id=users.id 


(5) 单 击 “ 测 试 ” 按 钮 ， 测 试 所 定义 的 SQL 语句 是 否 正 确 。 

(6) 在 高 级 “记录 集 ” 对 话 框 的 下 方 有 “数据 库 项 ”列表 框 ， 其 中 以 树 状 结构 显示 所 
选择 的 数控 连接 中 的 数据 表 、 视 图 及 存储 过 程 ; 在 右 侧 有 3 个 按钮 ， 即 SELECT、WHERE 
和 ORDER BY， 分 别 对 应 简单 记录 集 定义 中 的 字段 选择 、 记 录 过 滤 和 记录 排序 功能 。 使 用 
方法 是 : 先 选 中 某 一 字段 ， 然 后 再 单 击 其 中 的 一 个 按钮 。 

(7) 如 果 要 在 SQL 语句 中 使 用 变量 参数 ， 可 以 在 “参数 ”列表 框 中 对 查询 变量 进行 
定义 : 单 击 加 按钮 ， 随 即 弹 出 如 图 10-29 所 示 的 对 话 框 。 


图 10-29 “编辑 参数 ”对 话 框 


其 中 ， 在 “名 称 ”文本 框 中 定义 变量 的 名 称 ， 在 “类 型 ”下 拉 列 表 框 中 选择 变量 的 数 
据 类 型 ， 在 “ 值 ” 文 本 框 中 指定 查询 变量 的 值 ， 通 常 是 URL 参数 或 表单 变量 ， 这 些 参数 通 
过 $_POST 或 $_GET 数组 求 出 ， 如 $_POST[“usemame”]。 在 “默认 值 ” 文 本 框 中 定义 默认 
条 件 下 的 默认 变量 值 ， 设 置 完毕 后 ， 单 击 “确定 ”按钮 即 可 ， 并 返回 到 记录 集 定义 主 窗口 ， 
然后 将 刚刚 定义 的 变量 根据 需要 添加 到 先前 输入 的 SQL 语句 的 合适 位 置 处 。 

(8) 单 击 数据 集 定义 窗口 中 的 “测试 ”按钮 ， 测 试 其 SQL 语句 的 正确 性 。 测 试 通过 
后 ， 单 击 “ 确 定 ” 按 钮 ， 将 该 记录 集 添 加 到 “ 绑 定 ” 面 板 的 可 用 内 容 资 源 列表 中 。 

(9) 将 数据 集 输 出 到 页 面 中 ， 其 方法 与 简单 记录 集 在 网 页 中 输出 的 处 理 方式 相同 ， 这 
里 不 再 袭 述 。 


10.3.2 ”分 页 显示 查询 结果 


Dreamweaver 提供 了 一 些 服 务 器 行为 ， 用 于 快速 实现 各 种 标准 的 数据 库 操 作 。 要 实现 记 
录 集 分 页 显示 ， 主 要 用 到 以 下 几 种 服务 器 行为 。 

口 使 用 “重复 区 域 ” 服 务 器 行为 或 “动态 表格 ”服务 器 行为 创建 一 个 动态 表格 ， 用 
于 显示 记录 集 内 的 多 条 记录 。 

口 ”使 用 “记录 集 导 航 条 ”服务 器 行为 创建 文本 或 图 像 形式 的 导航 链接 ， 以 便 在 不 同 
记录 组 之 间 切 换 。 

口 ”使 用 “记录 集 导 航 状态 ”服务 器 行为 创建 记录 集 计数 器 ， 以 显示 总 记录 数目 和 当 
前 页 显示 的 记录 号 范围 。 

下 面具 体 叙 述 在 Dreamweaver 中 如 何 实现 数据 分 页 ， 其 步 又 如 下 : 

(1) 打开 PHP 站 点 ， 并 在 站 点 文件 夹 内 新 建 一 个 PHP 动态 网 页 。 

(2) 利用 简单 “记录 集 ” 对 话 框 创建 一 个 记录 集 ， 如 图 10-30 所 示 ， 在 这 里 将 记录 集 
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命名 为 studentrs， 从 表 stu_person 中 检索 数据 ， 并 选中 “ 列 ” 栏 中 的 “全 部 ” 单 选 按钮 ， 
以 显示 所 有 数据 列 。 

(3) 在 此 页 面 中 添加 一 个 动态 表格 ， 用 于 显示 记录 集 内 容 ， 如 图 10-31 所 示 ， 在 该 对 
话 框 中 设置 每 页 显示 5 条 记录 ， 单 击 “ 确 定 ”按钮 即 可 在 网 页 中 成 功 添加 动态 表格 ， 并 利 
用 表格 工具 对 动态 表格 的 属性 进行 设置 。 


图 10-30 简单 “记录 集 ” 对 话 框 图 10-31 “动态 表格 ”对 话 框 

(4) 把 网 页 中 的 插入 点 移动 到 动态 表格 的 左边 ， 选 择 “ 插 入 ”一 “数据 ”一 “显示 记 
录 计 算 ” 一 “记录 集 导 航 状态 ”命令 ， 然 后 在 “记录 集 导航 状态 ”对 话 框 中 选择 记录 集 
studentrs， 并 单 击 “确定 ” 按 钮 ， 如 图 10-32 所 示 。 

(5) 把 网 页 中 的 插入 点 移动 到 动态 表格 的 右边 ， 选 择 “ 插 入 ”一 “数据 ”一 “记录 集 
导航 条 ”命令 ， 然 后 在 “记录 集 导航 条 ”对 话 框 中 选择 记录 集 studentrs， 并 单 击 “ 确 定 ” 
按钮 ， 如 图 10-33 所 示 ， 其 中 ， 在 “显示 方式 ” 栏 中 有 两 个 选项 : 文本 和 图 像 ， 在 这 里 选 
中 第 一 项 。 


范例 : 记录 1 到 5 (总 共 10 个 记录 ) 


图 10-32 “记录 集 导航 状态 ”对 话 框 图 10-33 “记录 集 导航 条 ”对 话 杠 
(6) 以 上 步骤 完成 后 ， 动 态 网 页 页 面 将 变 成 如 图 10-34 所 示 的 外 观 ， 在 其 上 部 将 显示 


每 页 列 出 记录 的 起 止 记录 号 以 及 总 的 记录 数 ， 下 面 是 导航 条 按钮 ， 用 户 可 以 通过 单 击 它 浏 
览 各 页 。 


记录 {studentrs.FirstRecord} 到 {studentrs.LastRecord} (总 共 天 


|class_ id 


加 ex 下 jt 
[studentrs. nane}| {student rs. i agej|{studentrs, st_id}|{studentrs. class_id} 
如 条 件 则 电 示 . 


ELTITE IEE 
图 10-34 ”动态 表格 


用 户 设计 完成 后 ， 可 以 将 网 页 设计 视图 切换 到 代码 视图 ， 阅 读 自动 生成 的 PHP 代码 ， 
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然后 在 浏览 器 中 对 导航 条 进行 测试 ， 其 运行 效果 如 图 10-35 所 示 。 


/ 利用 服务 时 行为 快 带 实 现 记录 集 分 页 到 


记录 6 到 10 (总 共 16) 


st_id 
日 


图 10-35 分 页 显示 数据 记录 的 网 页 运行 效果 


10.3.3 ”搜索 /结果 页 的 创建 


为 了 给 动态 网 站 添加 搜索 功能 ， 通 常 需 要 创建 一 个 搜索 页 和 结果 页 ， 在 搜索 页 中 ， 访 
问 者 通过 HTML 表单 输入 搜索 参数 并 将 参数 传递 给 服务 器 上 的 结果 页 ， 由 结果 页 获取 搜索 
参数 ， 连 接 到 数据 库 并 根据 数据 库 进 行 查询 ， 创 建 记录 集 并 显示 其 内 容 。 

在 Dreamweaver 中 创建 显示 搜索 结果 的 PHP 动态 网 页 时 , 需要 获取 搜索 参数 的 值 并 根 


据 其 值 来 构建 。 
口 ” 若 只 传递 了 一 个 搜索 参数 ， 则 可 以 用 简单 “记录 集 ” 对 话 杠 来 创建 带 有 筛选 条 件 
的 记录 集 。 


口 车 传递 了 两 个 或 更 多 搜索 参数 ， 则 必须 使 用 高 级 “记录 集 ” 对 话 框 来 创建 记录 集 ， 
而 且 还 需要 设置 一 些 变量 ， 变 量 的 数目 与 搜索 参数 的 数目 相等 。 

下 面 举 一 个 实例 来 介绍 搜索 /结果 页 的 创建 步骤 ， 本 实例 要 求 按 班 级 名 称 查 询 学 生 记 
录 ， 当 从 下 拉 列 表 框 中 选择 一 个 班级 名 称 并 单 击 “查找 ”按钮 后 ， 系 统 将 以 表格 形式 列 出 
该 班级 的 学 生 信息 ， 其 步骤 如 下 : 

(1) 在 Dreamweaver 中 打开 PHP 站 点 ， 新 建 一 个 网 页 ， 在 该 页 中 插入 一 个 表单 ，method 
属性 设置 为 post， 然 后 在 表单 中 插入 一 个 列表 框 并 命名 为 class id， 在 列表 框 后 插入 一 个 提 
交 按 钮 ， 如 图 10-36 所 示 。 


| chart10-3. php* 
! JPOPPPR .PHTPPPR (PPPPPR LS PPPPR FPP PPPPPE PPPOE 5 PEE + PP tHE | 


图 10-36 网 页 中 的 表单 及 其 表单 元 素 
(2) 在 Dreamweaver 中 打开 PHP 站 点 ， 新 建 一 个 网 页 ， 仍 然 将 前 面 创建 好 的 数据 库 
连接 constu 加 入 到 本 网 页 中 ， 并 在 该 网 页 中 设置 一 个 简单 记录 集 ， 该 记录 集 从 班级 列表 中 
提取 全 部 信息 ， 如 图 10-37 所 示 。 
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(3) 再 创建 一 个 简单 记录 集 ， 从 学 生 列 表 中 检索 学 号 st id、 姓 名 name、 人 性 别 sex、 
年 龄 age 等 信息 , 并 为 该 记录 集 设 置 一 个 筛选 条 件 , 把 班级 编号 class_id 字段 的 值 与 从 列表 
框 中 选择 的 值 进行 比较 ， 所 以 在 “筛选 条件 选 项 的 第 二 个 下 拉 菜 单 中 应 选择 “表单 变量 ”， 
在 右边 的 文本 框 中 应 输入 先前 所 创建 的 下 拉 列 表 框 名 称 “class id”, 其 情形 如 图 10-38 所 示 。 


图 10-37 创建 班级 下 拉 列 表 数 据 源 的 记录 集 图 10-38 ”创建 有 筛选 条 件 的 记录 集 
(4) 将 前 面 创建 的 列表 框 class_id 绑 定 到 班级 列表 记录 集 上 ， 方 法 是 在 页 面 设 计 视 图 
窗口 中 选择 列表 框 ， 在 属性 检查 器 上 单 击 “ 动 态 ” 按 钮 ， 打 开 “ 动 态 列表 /菜单 ”对 话 框 ; 
然后 在 “来 自 记录 集 的 选项 ”列表 框 中 选择 刚刚 所 创建 的 班级 列表 记录 集 ， 从 “ 值 ” 和 “ 标 
签 ” 列 表 框 中 选择 class id 列 ， 在 “选取 值 等 于 ”文本 框 中 输入 PHP 代码 块 : <?php 
$_post['class id] ?>， 如 图 10-39 所 示 。 


图 10-39 绑 定 下 拉 列 表 框 
(5) 在 表单 下 方 插入 一 个 动态 表格 ， 用 于 显示 从 列表 框 中 所 选 班级 的 学 生 记 录 信 息 ， 
如 图 10-40 所 示 。 


sex [age st_id |class_id 
| ET mame] |{stuinfo. sex} |{stuinfo. age} |{stuinfo. st_id} |{stuinfo. class_id} 


图 10-40 添加 动态 表格 


(6) 在 页 面 设计 视图 窗口 中 选择 动态 表格 ， 选 择 “插入 ”一 “数据 ”选项 卡 中 的 “ 显 
示 区 域 ”命令 按钮 画 由 ， 单 击 旁 边 的 向 下 三 角 按钮 ， 在 弹出 的 下 拉 菜 单 中 选择 “如 果 记 录 集 
不 为 空 则 显示 ”命令 ， 并 在 随后 弹出 如 图 10-41 所 示 的 对 话 框 ， 在 该 对 话 框 中 选择 学 生 列 
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表 所 在 的 记录 集 。 


图 10-41 设置 显示 区 域 
(7) 至 此 页 面 设计 完成 ， 按 F12 键 可 浏览 程序 执行 的 页 面 效 果 ， 如 图 10-42 所 示 。 


请 选择 班级 [5317 本 记 


hame eexlage[st_id|class id 
hame3 MM [32 [3 [05311 
Panel0 [32 [io [os311 
hamel3 [24 [13 [05311 
namel4l [23 [14 lo5311 


三 三 三 三 三 下 人 Bt 所-[Kow -及 


图 10-42 浏览 搜索 /结果 页 运行 效果 
10.3.4” 主 /详细 记录 页 的 创建 


主 /详细 记录 页 是 一 种 比较 常用 的 页 面 组 合 ， 它 由 主页 和 详细 页 所 组 成 ， 通 过 两 个 层次 
来 显示 从 数据 库 中 检索 的 信息 。 主 /详细 记录 页 组 合 形式 的 创建 思想 是 : 在 主页 上 显示 出 通 
过 查询 返回 的 所 有 记录 部 分 信息 的 列表 ， 而 且 每 条 记录 都 包含 一 个 超 链接 ， 当 单 击 主 记 录 
页 上 的 超 链接 时 打开 详细 页 ， 并 传递 一 个 或 多 个 URL 参数 ， 在 详细 页 中 读 取 URL 参数 并 
根据 这 些 参 数 的 值 执行 数据 库 查 询 ， 以 检索 关于 选 定 记录 的 更 多 详细 信息 并 显示 出 来 。 

在 Dreamweaver 中 ， 可 以 通过 添加 相关 的 服务 器 行为 来 快速 生成 主 /详细 记录 页 ， 主 要 
包括 以 下 步 又; 

(1) 创建 主 记 录 页 ， 并 创建 与 详细 页 的 链接 : 在 Dreamweaver 中 打开 PHP 站 点 ， 新 
建 一 个 网 页 ， 为 了 和 后 面 的 详细 记录 页 区 分 ， 可 将 此 页 命名 为 main.php， 并 将 网 页 标题 设 
置 为 “学 生 基 本 情况 ”; 然后 以 学 生 数 据 表 为 数据 源 ， 利 用 简单 记录 集 对 话 框 在 该 网 页 中 
创建 一 个 记录 集 ， 并 以 动态 表格 的 形式 来 显示 该 记录 集 。 

(2) 在 动态 表格 上 方 插入 一 个 记录 集 导航 按钮 组 ， 其 方法 在 前 面 已 做 过 介绍 ， 设 置 的 
相关 情形 如 图 10-43 所 示 。 


El] 

2 站 
显示 方式 : G ”文本 取消 
站 如 助 


图 10-43 “记录 集 导 航 条 ”对 话 框 
(3) 在 动态 表格 右 侧 增加 一 列 ， 其 方法 是 将 光标 定位 到 该 动态 表格 的 最 右 侧 ， 然 后 用 
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鼠标 右键 单 击 最 右 侧 的 单元 格 ， 在 弹出 的 快捷 菜单 中 选择 “表格 ”一 “插入 列 ” 命 令 ， 然 
后 在 其 第 一 行 和 第 二 行 分 别 插入 “操作 ”和 “浏览 成 绩 ”， 如 图 10-44 所 示 。 选 中 “浏览 
成 绩 ”, 并 在 属性 检查 器 的 “链接 ” 框 中 输入 以 下 URL 并 附加 一 个 参数 : detail php?stid=<?php 
echo $row_stuinfo['stid']; ?>， 该 URL 的 功能 就 是 从 主页 链接 到 详细 页 ， 其 中 detail.php 是 即 
将 创建 的 详细 页 文件 名 ， 单 击 “ 浏 览 成 绩 ” 链 接 时 会 通过 stid 参数 将 学 生 的 学 号 传递 到 详细 
页 中 。 


图 10-44 插入 浏览 记录 的 超 链接 列 

(4) 创建 详细 页 ， 在 PHP 站 点 中 新 建 一 个 网 页 ， 并 命名 为 detail.php， 然 后 将 文档 标 
题 设 置 为 “该 学 生 详 细 信息 ”并 根据 获取 的 参数 查找 请 求 的 记录 ， 然 后 利用 高 级 “记录 集 ” 
对 话 框 创建 一 个 记录 集 以 便 从 学 生 表 (student) 、 课 程 表 (coursetb) 和 成 绩 表 (scores) 
中 检索 选 定 学 生 的 成 绩 数据 ， 使 用 的 SQL 语句 如 下 : 


SELECT coursetb.coursename，coursetb term，scores.score，student.stname FROM coursetb, 
scores, student WHERE coursetb.courseid=scores.courseid AND student.stid=stuid 


其 中 在 WHERE 子 句 部 分 包含 了 一 个 名 为 stuid 的 变量 ， 该 变量 是 通过 高 级 “记录 集 ” 
对 话 框 的 “变量 ”区 域 来 定义 的 ， 该 变量 的 类 型 为 Text， 默 认 值 为 081101， 运 行 值 为 
$_GET[stid]， 如 图 10-45 所 示 。 


图 10-45 高 级 “记录 集 ” 对 话 框 


(5) 在 详细 页 中 插入 一 个 动态 表格 ， 用 于 显示 主页 中 动态 连接 的 详细 记录 数据 ， 然 后 
在 该 动态 表格 前 添加 : <p align="center"> 该 学 生成 绩 为 </p>。 

(6) 保存 所 有 文件 ， 然 后 在 浏览 器 中 运行 主页 ， 其 效果 如 图 10-46 所 示 ， 单 击 “ 浏 览 
成 绩 ” 超 链接 ， 弹 出 如 图 10-47 所 示 的 在 详细 页 上 检索 到 的 记录 。 
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ex [birthday 


og1107 让 1990-05-01 |og311 


081108 | 向 小 : 1989-08-05 |08311 


os1109 | 张强 民 1989-08-11 |08311 |5 


os1110 | 张萌 1991-07-22 |o8511 


osl111 1990-03-18 |08412 


第 一 页 前 一 页 下 一 页 最 后 一 页 


该 学 生成 绩 为 


coursename term 

| 计算 机 基础 。 |2009/2010 学 年 第 1 学 期 
工程 力学 2009/2010 学 年 第 1 学 期 
高 散 数 学 [2009/2010 学 年 第 2 学 期 


Ill ll 网 ae 


图 10-47 详细 页 


10.4 记录 的 添加 、 删 除 与 更 新 


利用 Dreamweaver 提供 的 表单 设计 工具 和 服务 器 行为 面板 可 以 方便 地 实现 数据 库 记 录 
的 添加 、 删 除 及 数据 更 新 等 数据 库 操作 功能 。 


10.4.1 数据 记录 的 添加 


在 Dreamweaver 中 可 以 使 用 插入 记录 表单 向 导 和 逐 块 生成 记录 添加 页 面 两 种 方法 实现 
数据 的 添加 功能 。 


1. 使 用 向 导 实现 数据 记录 的 添加 


使 用 插入 记录 表单 向 导 可 以 通过 单个 操作 创建 记录 添加 页 面 的 基本 模块 ， 可 自动 把 
HTML 表单 和 “插入 记录 ”服务 器 行为 同时 添加 到 页 面 中 ， 操 作 步 又 如 下 : 

(1) 在 PHP 站 点 中 新 建 一 个 网 页 。 

(2) 选择 “插入 ”一 “数据 ”一 “插入 记录 ”一 “插入 记录 表单 向 导 ” 命 令 ， 如 图 10-48 
所 示 。 
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(3) 弹出 如 图 10-49 所 示 的 “插入 记录 表单 ”对 话 框 ， 设 置 以 下 各 项 : 

@ 在 “连接 ”列表 框 中 选择 一 个 数据 库 连 接 。 

@ 在 “表格 ”列表 框 中 选择 要 向 其 插入 记录 的 数据 库 表 。 

@ 在 “插入 后 , 转 到 ”文本 框 中 输入 将 记录 成 功 插 入 到 数据 库 表 后 要 跳 转 到 哪个 页 面 ， 
若 此 项 留 空 ， 则 插入 记录 后 仍 打开 当 前 页 面 。 

@ 在 “表单 字段 ”列表 框 中 ， 指 定 要 包括 在 记录 添加 表单 的 表单 控件 ， 以 及 每 个 表单 
控件 对 应 的 数据 库 表 字段 。 

@ 在 “表单 字段 ”编辑 窗 格 中 显示 了 数据 库 表 中 各 字段 在 PHP 页 面 中 显示 的 数据 类 
型 以 及 标签 名 称 等 ， 可 以 通过 单 击 国 按钮 和 国 按钮 来 增加 和 删除 要 在 页 面 中 显示 的 字段 数 
据 ， 也 可 单 击 圈 性 按钮 来 调整 HTML 表单 控件 顺序 。 


图 10-48 选择 “插入 记录 表单 向 导 ” 命 令 图 10-49 “插入 记录 表单 ”对 话 框 

(4) 指定 每 个 数据 输入 域 在 HTML 表单 上 的 显示 方式 ， 方 法 是 先 用 鼠标 选中 “表单 
字段 ” 窗 格 中 的 一 行 ， 然 后 就 可 以 对 该 行 所 对 应 的 数据 列 设置 相关 选项 。 

(5) 单 击 “ 插 入 记录 表单 ”对 话 框 中 的 “确定 ”按钮 ， 此 时 ，Dreamweaver 将 表单 和 
“插入 记录 ”服务 器 行为 添加 到 页 面 中 ， 如 图 10-50 所 示 。 表 单 被 包含 在 <table></table> 表 
格 标记 之 间 ， 可 通过 设置 表格 的 相关 属性 来 修改 表单 的 外 观 布局 。 如 果 要 对 “插入 记录 ?” 
服务 器 行为 进行 编辑 ， 可 打开 “服务 器 行为 ”面板 ， 双 击 该 服务 器 行为 即 可 进行 编辑 。 

(6) 按 F12 键 浏览 程序 运行 效果 ， 如 图 10-51 所 示 。 


sd 
ody> CEorm#forml > [| 


图 10-50 ”插入 记录 表单 设计 视图 图 10-51 插入 记录 表 运行 效果 
2. 了 逐 块 生成 记录 添加 页 面 
使 用 表单 工具 和 “服务 器 行为 ”面板 也 可 分 步骤 创建 记录 添加 页 面 的 基本 模块 ， 其 中 
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包括 两 个 步骤 ， 首 先 将 表单 添加 到 页 面 ， 接 收 用 户 输入 数据 ， 然 后 添加 “插入 记录 ”服务 
器 行为 以 便 在 数据 库 表 中 插入 记录 。 

首先 在 页 面 中 添加 表单 ， 其 步骤 如 下 : 

(1) 在 PHP 动态 网 站 站 点 中 新 建 一 个 PHP 动态 网 页 ， 然 后 使 用 Dreamweaver 设计 工 
具 对 该 页 面 进行 布局 。 

(2) 插入 一 个 表单 ， 然 后 在 该 表单 内 插入 一 个 表格 ,用 于 布局 要 添加 的 数据 表 字段 信 
息 , 同时 添加 “提交 ”按钮 、“ 重 置 ”按钮 ,以 及 一 组 单 选 按钮 和 班级 下 拉 列 表 ， 如 图 10-52 
所 示 。 

(3) 利用 简单 “记录 集 ” 对 话 框 创建 一 个 记录 集 作为 班级 下 拉 列 表 的 数据 源 ， 该 记录 
集 只 包含 班级 编号 字段 。 然 后 选中 班级 下 拉 列 表 ， 通 过 设置 “动态 列表 /菜单 ”对 话 框 中 的 
各 项 内 容 ， 将 下 拉 列 表 框 绑 定 到 该 记录 集 上 ， 如 图 10-53 所 示 。 


动态 列表 / 药 单 


图 10-52 设置 插入 记录 所 用 的 表单 集 表单 元 素 图 10-53 绑 定 “班级 ”下 拉 列 表 
(4) 添加 “插入 记录 ”的 服务 器 行为 ， 方 法 是 : 选择 “插入 ”一 “数据 ”一 “插入 记 
录 ” 一 “插入 记录 ”命令 ， 弹 出 “插入 记录 ”对 话 框 ， 其 中 在 “ 列 ” 文 本 框 中 罗列 了 数据 
集中 的 所 有 数据 字段 ， 逐 个 选中 各 数据 项 ， 分 别 设 置 对 应 的 表单 控件 ， 如 图 10-54 所 示 。 


图 10-54 编辑 插入 列 内 容 


(5) 切换 到 代码 视图 ， 在 表单 结束 标记 </form> 后 插入 如 下 PHP 代码 : 
<?php if(isset($_post["button"])&&$Result1)echo" 添 加 成 功 ! "; ?> 


其 中 ，Resultl 是 Dreamweaver 系统 自动 生成 的 数据 集 名 称 。 
(6) 按 F12 键 ， 运 行程 序 ， 并 添加 一 条 记录 进行 测试 ， 如 图 10-55 和 图 10-56 所 示 。 
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CT Oment 


图 10-55 插入 数据 记录 前 的 页 面 图 10-56 插入 数据 记录 后 的 页 面 
10.4.2 ”删除 数据 


通常 PHP 动态 网 站 应 包含 用 于 删除 数据 表 数 据 记 录 的 页 面 , 在 Dreamweaver 中 ， 可 以 
在 网 页 中 添加 “删除 记录 ”服务 器 行为 来 生成 记录 删除 页 面 。 下 面 通过 设计 删除 学 生 记 录 
程序 的 例子 来 简单 介绍 删除 记录 页 面 的 设计 方法 。 

(1) 在 PHP 站 中 创建 一 个 PHP 动态 网 页 。 

(2) 利用 简单 “记录 集 ” 对 话 框 创建 一 个 记录 集 并 命名 为 studentrs， 然 后 插入 一 个 动 
态 表格 ， 用 于 显示 该 记录 的 内 容 。 

(3) 在 动态 表格 最 右 侧 插入 一 列 ， 并 将 在 其 列 头 处 输入 “操作 ”， 在 第 二 行 输入 “ 删 
除 记录 ”， 选 中 “删除 记录 ”文本 。 然 后 在 属性 面板 的 “链接 ”文本 框 中 输入 “chart10- 
7.php?stid=<?php echo $row_studentrs['stid']; ?>”。 

(4) 在 动态 表格 上 方 插入 一 个 记录 集 导航 条 ， 并 在 导航 条 右 侧 增加 一 列 ， 在 其 中 插入 
一 个 记录 集 导 航 状态 ， 如 图 10-57 所 示 。 


{studentrs, FirstRecord} 到 
Irs, i 塌 共 


图 10-57 ” 带 有 记录 集 导 航 条 的 动态 表格 


(5) 在 “服务 器 行为 ”面板 上 单 击 “ 加 号 ”按钮 吕 ， 从 弹出 的 菜单 中 选择 “删除 记录 ” 
命令 ， 然 后 在 弹出 的 “删除 记录 ”对 话 框 中 设置 相关 选项 ， 如 图 10-58 所 示 。 


图 10-58 “删除 记录 ”对 话 框 
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(6) 在 浏览 器 中 打开 网 页 ， 并 记录 删除 功能 进行 测试 如 图 10-59 和 图 10-60 所 示 。 


[后 无 标题 文 着 - Wiaae 


81202 河 [1s89-01-29 
B1203 E 1590-05-26 
81204 1989-02-10 
81206 Ri 1989-09-20 
81210 1389-05-01 
81216 1989-03-19 
81218 |1990-10-09 
81220 | 1990-03-18 
81221 1s89-11-12 


第 -页 前- 页。 下 -~ 页。 最 后 一 页 记录 11 到 20 (总 共 (22 盆 记录 ) 


学 生 编 号 E 但 生 备 月 

81202 和 和 [1989-01-29 
81205 1980-035-26 
31204 [989-02-10 
81205 1969-09-20 
81215 1989-05-19 
B1218 1900-10-09 
81220 1980-03-19 
B1221 和 [1989-11-12 
B1241 志和 9s0-01-50 


图 10-60 ”删除 记录 后 的 页 面 
10.4.3 ”数据 记录 的 更 新 


在 Dreamweaver 中 ， 可 以 通过 可 视 化 操作 快速 生成 一 个 记录 更 新 页 ， 不 用 编写 代码 或 
编写 少量 代码 。 一 个 记录 更 新 页 包括 以 下 3 个 构造 模块 : 用 于 从 数据 库 表 中 检索 记录 的 过 
滤 记 录 集 ; 允许 用 户 修改 记录 数据 的 HTML 表单 ; 用 于 更 新 数据 库 表 的 “更 新 记录 ”服务 
器 行为 。 下 面 利用 “更 新 记录 表单 向 导 ” 来 创建 更 新 数据 记录 页 面 ， 其 步骤 如 下 : 

(1) 在 PHP 站 中 创建 一 个 PHP 动态 网 页 。 

(2) 利用 简单 “记录 集 ” 对 话 框 创建 一 个 记录 集 并 命名 为 Recordsetl， 然 后 添加 “更 
新 记录 ”的 服务 器 行为 ， 方 法 是 : 选择 “插入 ”一 “数据 ”一 “更 新 记录 ”一 “更 新 记录 
表单 向 导 ” 命 令 ， 弹 出 “更 新 记录 表单 ”对 话 框 ， 在 其 中 设置 “连接 ”和 “要 更 新 的 表格 ” 
等 各 项 ， 在 “唯一 键 列 ”下 拉 列 表 框 中 选择 数据 库 表 中 的 主 关键 字段 ， 然 后 在 “表单 字段 ” 
列表 框 中 对 要 更 新 的 数据 字段 进行 增删 等 编辑 操作 ， 如 图 10-61 所 示 。 

(3) 设置 完 “ 更 新 记录 表单 ”对 话 框 中 的 各 项 之 后 ， 单 击 “ 确 定 ”按钮 ， 在 页 面 中 出 
现 一 个 带 若 干 文本 框 的 表格 ， 然 后 在 该 表格 上 部 添加 一 行 ， 并 将 该 行 合 并 为 一 个 单元 格 ， 
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在 合并 后 的 单元 格 中 插入 一 个 “记录 集 导 航 条 ”， 如 图 10-62 所 示 。 


[me 可 
要 更新 表格 stvisnt 3 
hi 好 自生 
叭 -名 列 [st 下 数字 
下 更 新 后 ， 轩 到 Ei 
静音 字 耻 二 二 | ERE) 
Stid Stid; 
stnane Staane 文本 字段 文本 
soe 文本 及。 数字 
birthdsy Birthdsy: 文本 字段 日 区 
mooni Mooci 六 本 给 性 本 到 
| 
时 为 友 二 DE 
奖杯 [<?php echo row Recordsetl[ s' > 


图 10-61 “更 新 记录 表单 ”对 话 框 图 10-62 更 新 记录 表单 


(4) 在 正 浏览 器 中 运行 该 页 面 ， 其 效果 如 图 10-63 所 示 。 在 相应 文本 框 中 输入 新 内 
容 ， 然 后 再 单 击 “ 更 新 记录 ”按钮 ， 即 可 将 新 内 容 写 入 到 数据 表 中 。 


] 文件 四 ”久久 E) 查看 如 收藏 天 的 工具) 帮助 


Stname: [F 可 
Bday 
Cs | 
[ES | 
wea | | 


CT me 


图 10-63 更 新 记录 表单 运行 效果 


10.5 案例 剖析 : 网 上 留言 簿 的 实现 


网 上 留言 簿 是 常见 的 互联 网 应 用 之 一 , 本 实例 将 借助 Dreamweaver 来 实现 一 个 PHP 动 
态 网 页 的 留言 短 。 在 制作 留言 板 的 动态 网 页 之 前 ， 需 要 创建 一 个 数据 库 ， 其 中 包含 两 个 数 
据 表 , 一 个 用 于 保存 用 户 的 信息 , 另 一 个 用 于 保存 留言 板 上 的 留言 内 容 。 本 实例 采用 MySQL 
创建 该 数据 库 。 


10.5.1 程序 功能 介绍 
本 实例 的 主要 功能 包括 用 户 认证 及 登录 、 合 法 用 户 查 看 留言 信息 和 合法 用 户 添加 留言 


信息 。 为 此 ， 需 要 建立 一 个 数据 库 ， 本 例 取 名 为 webnotedb， 在 数据 库 中 创建 两 个 表 : users 
及 notecontent， 分 别 用 于 保存 用 户 信息 和 留言 内 容 信息 。 其 结构 如 表 10-1 和 表 10-2 所 示 。 
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表 10-1 users 表 结构 


用 户 号 字段 类 型 说 明 
Id (主键 ) tinyint 言 顺序 号 
name char 用 户 名 
Email char 电子 邮箱 
NoteContent varchar 言 内 容 
Date date 言 时 间 

表 10-2 notecontent 表 结 构 

用 户 号 字段 类 型 说 明 
Id (主键 ) tinyint 留言 顺序 号 
name, char 用 户 名 
Email char 电子 邮箱 
NoteContent varchar 留言 内 容 
Date date 留言 时 间 


网 上 留言 笑 的 首页 是 用 户 登录 页 面 ， 如 图 10-64 所 示 ， 当 用 户 输入 合法 的 用 户 名 和 密 
码 后 ， 单 击 “ 提 交 ” 按 钮 ， 系 统 将 自动 转 入 如 图 10-65 所 示 的 留言 浏览 页 ， 可 以 查看 到 所 
有 的 留言 。 


三 用 户 各 好 页 而 -Tindors TREE 
SiS 司 5 ea d+ x 

| 广内 D ELECTRO ETT] 
证 收藏 天 。 大 用户 站 对 而 


网 上 留言 答 


maa 


文件 加 ”如 多 加 查看 ” 收 评 天 ) 工具 Q) 各 二 。。。 


ee 


和 
CHENGDU ELECTROMECHANICAL COLLEGE 


宣言 器 去 | 营 汇 | 者 闻 | 杂志 | 效 御 之 芭 


图 10-65 浏览 留言 窗口 
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单 击 如 图 10-65 所 示 的 浏览 留言 页 上 面 的 “我 要 留言 ” 超 链接 ， 系 统 将 转 入 到 添加 留 
言 页 面 ， 输 入 相应 内 容 后 ， 单 击 “ 插 入 记录 ”按钮 即 可 添加 新 的 留言 ， 如 图 10-66 所 示 。 
留言 如 图 添加 成 功 ， 将 弹出 如 图 10-67 所 示 的 页 面 。 


/无 标题 文档 - Windows Tateraet Explerer 


wnt lx he 


于 助 00 


ER 


图 10-66 添加 留言 窗口 
单 击 图 10-66 所 示 页 面 上 部 的 “留言 管理 ” 超 链接 ， 弹 出 如 图 10-68 所 示 的 修改 留言 
记录 的 页 面 。 通 过 向 文本 框 中 输入 新 内 容 ， 然 后 单 击 “ 更 新 记录 ”按钮 即 可 将 更 新 的 内 容 
提交 到 数据 库 服务 中 。 


」 文件 中 辆 将 到 ) 查看 WD 收 蕊 严 他 ) 工具 CD 帮助 0 
这 收 草 严 。 大 无 和 是 文档 


第 一 页 前 一 页 下 一 页 最 后 一 页 


EECIEEEESEC 


Fi1005-09 


添加 记录 成 功 
| 三 三 三 辜 Bermt [rE 
图 10-67 添加 留言 成 功 消息 杠 图 10-68 ”修改 留言 页 面 


10.5.2 程序 代码 分 析 


首先 为 网 上 留言 短 设 计 一 个 用 户 登录 程序 ， 该 程序 可 以 借助 Dreamweaver 来 生成 ， 其 
步骤 为 : 先 在 网 页 中 添加 一 个 数据 集 ， 用 于 连接 用 户 表 ， 然 后 在 网 页 内 插入 一 个 表单 ， 之 
后 ， 选 择 “ 插 入 ”一 “数据 ”一 “用 户 身份 验证 ”一 “登录 用 户 ” 命 令 ， 如 图 10-69 所 示 。 
随后 弹出 如 图 10-70 所 示 的 “登录 用 户 ” 窗 口 。 

在 “登录 用 户 ” 设 置 窗口 中 选择 使 用 的 连接 和 表格 、 用 户 名 列 、 密 码 列 等 选项 ， 然 后 
单 击 “确定 ”按钮 ， 系 统 将 自动 在 网 页 内 生成 一 个 用 户 登录 表单 ， 如 图 10-71 所 示 。 
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从 表单 获 职 输入 : | forn1 
用 户 名 字段 = |textfiela 
密码 字段 :|textfial2 
使 用 和 连接 验证 : |noterebcon 
表格 |users 


tlk 


| 


dl 


z 


用 户 名 列 : [rw 
Ge 
如 果 瑟 录 成 功 , 笠 到 :iinote mp 浏览 
厂 苇 到 前 一 个 VELC 加 果 它 存 在 ) 
加 果 有 好 失败 ， 轩 到 : Fw [ER 
基于 以 下 项 限制 访问 “ 用户 名 和 密码 
和 用户 名 、 密 码 和 访问 好 别 


Er | 


器 


图 10-69 ”选择 “登录 用 户 ” 命 图 10-70 “登录 用 户 ” 窗 口 


图 10-71 登录 用 户 表 单 


转 到 代码 视图 窗口 ， 将 看 到 如 下 程序 代码 。 


<?php require_once('../Connections/notewebcon.php'); ?> 
<?php 
if(!function_exists("GetSQLValueString")}X{ 
function GetSQLValueString($theValue, $theType, $theDefinedValue = ", $theNotDefinedValue = ") 
{ S$StheValue = get_magic_quotes_gpc() ? stripslashes($theValue): $theValue; 
StheValue = function_exists("mysql_real_escape_string")? mysql_real_escape_string($theValue): 
mysql_escape_string($theValue); 
switch($theType) 
{ 
case "text": 
StheValue =($theValue != ")? "" . $theValue . ” : "NULL"; 
break; 
case "long": 
case "int": 
StheValue =(theValue (= "")? Intval(theValue)"NULL"; 
break; 
case "double": 
StheValue =($theValue {= "")? "™ . doubleval($theValue). ™" : "NULL"; 
break; 
case "date": 
StheValue =($theValue = ™")? "" . $theValue .™ : "NULL"; 
break; 
case "defined": 
StheValue =($theValue != "")? $theDefinedValue : $theNotDefinedValue; 
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break; 

} 
return $theValue; } 
} 
mysql_select_db($database_notewebcon, $notewebcon); 
Squery_webnotecon = "SELECT users.Name, users.Password FROM users"; 
$webnotecon = mysql_query($query_webnotecon, $notewebcon)or die(mysql_error()); 
$row_webnotecon = mysql_fetch_assoc($webnotecon); 
S$totalRows_webnotecon = mysql_num_rows($webnotecon); 
?> 
<?php 
if(lisset($_SESSION)) 
{ 


} 
S$loginFormAction = $_SERVER[PHP_SELF]; 
iflisset($_GET[accesscheck])) 


session_start(); 


4 

$_SESSION['PrevUrl] = $_GET['accesscheck']; 
} 
iflisset($_POST[textfield])) 


$loginUsername=$_POST[textfield']; 
$password=$_POST[textfield11]; 
$MM_fldUserAuthorization = ""; 
$MM_redirectLoginSuccess = "allnote.php"; 
$MM_redirectLoginFailed = "shibai.htm"; 
$MM_redirecttoReferrer = false; 
mysql_select_db($database_notewebcon, $notewebcon); 
S$LoginRS_query=sprintf("SELECT Name, Password FROM users WHERE Name=%s AND 
Password=%s", 
GetSQLValueString($loginUsername, "text"), GetSQLValueString($password, "text")); 
$LoginRS = mysql_query($LoginRS_query, $notewebcon)or die(mysql_error()); 
S$loginFoundUser = mysql_num_rows($LoginRS); 
If($loginFoundUser) 
1 
$loginStrGroup = "; 
$_SESSION[MM_Username'] = $loginUsername; 
$_SESSION[MM_UserGroup'] = $loginStrGroup; 
lflisset($_SESSION[PrevUrl])&& false) 


{ 
$MM_redirectLoginSuccess = $_SESSION[PrevUrl]; 
} 
header("Location: " . $SMM_redirectLoginSuccess); 
} 
else 
1 
header("Location: ". $MM_redirectLoginFailed); 
} 
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?> 
<html > 
<title> 用 户 登 录 页 面 </title> 
<body> 
<center><h2><strong> 网 上 留言 往 </strong></h2></center> 
<form id="form1" name="form1" method="POST" action="<?php echo $loginFormAction; ?>"> 
<table width="251” border="0”align="center” cellpadding="0" cellspacing="0” bgcolor= 
'"#FF99FF"> 
<tr> <td height="34" colspan="2"><div align="center > 
<label> 
<input type="image" name="imageField" id="imageField" src="images/8.gif’ /> 
</label> 
用 户 登录 </div></td> </tr> 
<tr> 
<td width="83" height="34"><div align="center"> 用 户 名 </div></td> 
<td width="168"><label> 
<input type="text” name="textfield" id="textfield" /> 
</label></td> 
</tr> 
<tr> <td height="32"><div align="center"> 密 码 </div></td> 
<td><input name="textfield1" type="password" id="textfield1" /></td></tr> 
<tr><td height="40"><label> 
<div align="right"> 
<input type="submit" name="button" id="button" value=" 提 交 " /> 
</div> 
</label></td> 
<td><label> 
<div align="center > 
<input type="reset" name="button2" id="button2" value=" 重 置 " /> 
</div> 
</label></td> </tr> 
</table> 
</form> 
</body> 
</html> 
<?php 
mysql_free_result($webnotecon); 
?> 


接 下 来 就 是 设计 添加 留言 记录 、 更 新 留言 记录 以 及 查看 留言 记录 等 程序 ， 这 些 程序 的 
设计 方法 和 步骤 与 本 章 所 讲 的 记录 的 添加 、 更 新 和 查看 的 设计 方法 类 似 ， 这 里 不 再 更 述 。 


10.6 本 章 小 结 


本 章 着 重 介绍 了 如 何在 Dreamweaver CS4 中 设计 PHP 动态 网 页 ， 借 助 Dreamweaver 
中 的 一 系列 可 视 化 工具 可 以 设计 向 数据 库 添 加 记录 、 插 入 数据 、 删 除数 据 、 更 新 数据 等 一 
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系列 数据 库 操 作 。 


10.7 练 习 题 


1. 在 Dreamweaver 中 创建 数据 库 链接 时 将 生成 一 个 什么 样 的 PHP 文件 ? 它 包 含 哪些 
内 容 ? 存放 在 何 处 ? 

2. 为 了 避免 访问 MySQL 数据 库 时 出 现 乱码 现象 ， 应 该 在 数据 库 连 接 文件 中 添加 什么 
PHP 代码 ? 

3. 简 述 简单 记录 集 和 高 级 记录 集 各 自 的 特点 。 

4. 在 Dreamweaver 中 创建 分 页 显示 记录 的 页 面 ， 主 要 包括 哪些 步骤 ? 


10.8 上 机 实战 


1. 在 MySQL 中 建立 一 个 数据 库 Student， 其 中 包含 学 生 学 籍 状态 表 stu_state 和 学 生成 
绩 表 st_scores， 其 结构 如 表 10-3 和 表 10-4 所 示 。 


表 10-3 学 s 籍 状态 表 (stu_state) 结构 


字 段 名 数据 类 型 字段 说 明 键 引 用 
stid 学 生 编号 E 键 
stidname 姓名 
Class id 班级 
State | vw | 是 在 在 校 

表 10-4 ”学生 成绩 表 (st_scores) 结构 
字 段 名 数据 类 型 字段 说 明 键 引 用 
stid 学 生 编号 
tem 学 期 


Score int 成 绩 
2. 在 网 页 中 建立 一 个 表单 ， 和 输入 学 生成 绩 数据 ， 并 将 输入 的 学 生成 绩 数据 存 入 学 生成 
绩 表 st_scores 中 。 


3. 编写 一 个 PHP 程序 ， 查 询 学 生 学 籍 状态 表 stu_state 中 的 记录 ， 如 果 记 录 大 于 30， 
则 分 页 显示 。 
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PHP 中 类 与 对 象 的 应 用 

项 目的 需求 分 析 

项 目的 流程 设计 

在 PHP 程序 中 的 数据 库 操作 
MySQL 数据 库 管 理 系统 的 应 用 


本 章 导读 : 


本 章 通过 网 络 留言 板 系 统 实例 的 分 析 ， 详 细 介 绍 了 MySQL 数据 库 和 基于 PHP 与 
Apache 相 结 合 的 Web 应 用 程序 开发 。PHP 语言 是 开发 跨 操作 系统 平台 运行 的 Web 项 目的 
首选 语言 ， 也 是 目前 B/S 模式 下 开发 应 用 程序 使 用 最 广泛 的 开发 工具 之 一 。 希 望 读 者 通过 
了 解 网 络 留言 板 的 开发 过 程 ， 进 一 步 熟 悉 和 升华 PHP 基础 知识 ， 同 时 进一步 了 解 MySQL 
数据 库 系 统 的 应 用 。 


回回 罗网 加 


11.1 系统 概述 


网 络 留言 板 又 称 为 留言 簿 或 留言 本 ， 是 目前 网 站 中 使 用 较 广 泛 的 一 种 用 户 沟通 、 交 流 
的 平台 。 通 过 留言 板 ， 可 收集 来 自 不 同 用 户 的 意见 或 需求 信息 ， 并 可 做 出 相应 的 回复 ， 从 
而 实现 不 同 群体 及 不 同 客户 之 间 的 交流 与 沟通 。 


11.1.1 需求 分 析 


基于 网 络 留言 板 的 主要 用 途 ， 在 设计 该 系统 时 应 主要 包括 以 下 功能 
用 户 注 册 。 
用 户 登 录 。 
添加 留言 。 
浏览 留言 内 容 。 
回复 留言 。 
删除 留言 。 
设置 网 上 问卷 调查 题目 。 
进行 网 上 问卷 调查 与 统计 。 
当然 ， 以 上 功能 只 是 网 络 留言 板 最 基本 的 功能 ， 开 发 者 还 可 以 根据 需要 进一步 添加 其 
他 功能 。 读 者 不 妨 思考 一 下 ， 看 看 还 能 进行 哪些 创新 性 的 设计 。 


DoOOOOODO DO 
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11.1.2 ”流程 设计 


网 络 留言 板 系 统 的 用 户 分 为 两 类 : 一 类 是 没有 注册 的 用 户 , 即 留言 板 网 站 的 一 个 过 客 ， 
这 类 用 户 只 能 添加 新 的 留言 内 容 、 浏 览 留言 内 容 、 回 答 问卷 调查 题目 以 及 注册 网 站 ， 成 为 
正式 的 注册 用 户 ; 另 一 类 用 户 是 已 经 正式 注册 的 ， 这 类 用 户 通 过 身份 验证 后 ， 除 可 以 操作 
除 第 一 类 用 户 的 所 有 功能 之 外 ， 还 享有 回复 留言 、 删 除 留言 、 设 置 问卷 调查 题目 及 题目 选 
项 、 查 看 及 统计 调查 结果 等 功能 。 如 图 11-1 所 示 完 整地 描述 了 整个 系统 的 工作 流程 。 


回答 问卷 调查 题目 


用 户 注册 


图 11-1 网 络 留言 板 的 工作 流程 图 


11.2 数据库 设计 


数据 库 是 Web 信息 系统 中 所 有 数据 的 存储 位 置 ， 也 是 为 网 页 提供 动态 数据 的 数据 源 。 
所 以 ， 数 据 库 在 动态 网 站 设计 与 运行 中 占有 非常 重要 的 地 位 。 下 面 介绍 网 络 留言 板 所 涉及 
的 数据 库 设 计 。 


11.2.1 ”需求 分 析 及 逻辑 结构 设计 


本 项 目 使 用 MySQL 数据 库 作 为 整个 系统 的 后 台数 据 库 , 数据库 取 名 为 web_luntan_db， 
其 中 包含 了 4 个 表 : 用 于 存储 用 户 信息 的 Users 表 ， 用 于 存储 留言 内 容 的 Content 表 ， 用 于 
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记录 参与 问卷 调查 的 计算 机 IP 地 址 的 voteip 表 ， 用 于 存储 问卷 调查 内 容 的 voteitem 表 。 
表 11-1 一 表 11-4 分 别 是 这 4 个 表 的 逻辑 结构 。 


字段 名 称 


表 11-1 用 户 表 (Users) 结构 
数 据 和 请 述 备 注 


UserID 
UserPwd 


UserName 


registerTime 


字段 名 称 


用 户 号 主键 


8 


表 11-2 留言 记录 表 (Content) 结构 


ContId 


Varchar 


UserName 
Email 
HomePage 


CreateTime 
ParentTitleID 


字段 名 称 
IPAdress 
Count 


Varchar 
Varchar 
Varchar 
Varchar 
Varchar 


int 


数据 类 型 
varchar 


int 


全 地 址 主键 


表 11-4 投票 选项 表 (voteitem ) 结构 
描述 备注 


序号 主键 


VoteCount 


王 共 内 容 


西 
A 


11.2.2 ”数据 库 及 数据 表 的 建立 


首先 是 创建 数据 库 web_luntan db， 可 以 借助 于 phpMyAdmin 和 Navicat MySQL 工具 
创建 ， 也 可 以 通过 MySQL 客户 端 工具 MySQL Command Line Client 登录 数据 库 服务 器 ， 


在 命令 行 输入 下 列 语 


i 句 然 后 按 Enter 键 创建 。 


CREATE DATABASE IF NOT EXISTS web_luntan_db 
COLLATE 'gb2312_chinese_ci 


接 下 来 ， 按 同样 的 方法 ， 参 照 前 面 对 各 数据 表 逻 辑 结构 的 定义 ， 完 成 各 数据 表 的 物理 
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实现 。 其 对 应 的 SQL 语句 分 别 如 下 。 
口 用 户 表 (Users) 的 SQL 实现 语句 


CREATE TABLE Users ( 
userlD varchar(10) NOT NULL, 
UserPwd varchar(10) default NULL， 
UserName varchar(10) default NULL, 
registerTime date default NULL， 
PRIMARY KEY (userlD) 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312; 


口 ”留言 记录 表 (Content) 的 SQL 实现 语句 


CREATE TABLE Content ( 
Contld int(11) NOT NULL auto_increment, 
Title varchar(200) NOT NULL, 
Words varchar(1000) NOT NULL, 
UserName varchar(50) NOT NULL， 
Headface varchar(50) default NULL， 
Emai varchar(50) default NULL， 
Homepage varchar(50) default NULL, 
CreateTime datetime default NULL, 
ParentTitlelD int(11) default NULL， 
PRIMARY KEY (Contld) 

) ENGINE=InnoDB DEFAULT CHARSET=gb2312; 


口 参与 投票 的 计算 机 他 地址 表 (voteip) 的 SQL 实现 语句 


CREATE TABLE voteip ( 
IPAdress varchar(50) NOT NULL， 
Count int(4) default NULL 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312; 


口 ” 投 票选 项 表 (SelectItem) 的 SQL 实现 语句 


CREATE TABLE Selectltem ( 
ID int(11) NOT NULL auto_increment, 
ltem varchar(50) NOT NULL， 
VoteCount int(11) NOT NULL， 
PRIMARY KEY (ID) 
) ENGINE=InnoDB DEFAULT CHARSET=gb2312; 


上 述 4 张 数据 表 中 ,最 后 一 行 语句 都 是 <ENGINE=InnoDB DEFAULT CHARSET=gb2312”。 
其 中 ，InnoDB 表示 所 建 数据 表 的 类 型 ，CHARSET 用 来 定义 数据 表 采 用 的 编码 类 型 ， 在 此 
定义 的 是 gb2312， 即 简体 中 文字 符 采 用 的 字符 编码 标准 类 型 。 


11.3 系统 公用 模块 设计 及 代码 编写 


在 进行 PHP 项 目 开发 之 前 ， 程 序 员 最 好 对 项 目 所 实现 的 功能 模块 进行 通盘 布局 ， 思 考 
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络 留言 板 


哪些 模块 具有 通用 性 ， 然 后 可 以 把 这 些 具有 通用 性 的 模块 组 合成 一 个 公用 模块 ， 也 可 以 将 
它们 统一 定义 为 一 个 类 来 实现 。 


11.3.1 ”用户 类 公用 模块 代码 的 设计 与 实现 


由 于 在 数据 库 web_luntan_db 中 的 用 户 表 (Users) 在 整个 系统 运行 中 使 用 的 频率 较 高 ， 
因此 可 定义 一 个 类 Users， 由 它 来 专门 负责 与 用 户 相 关 的 一 些 操作 。 该 类 的 实现 代码 如 下 : 


<?PHP 
class Users 
于 
var $linkdb; 
public $userlD; /用 户 名 
public $UserPwd; // 用 户 密码 
public $UserName; // 显 示 名 称 
public $regsitertime; 
function __construct() // 定 义 构造 函数 ， 用 于 连接 数据 库 
Sthis->linkdb = mysqli_connect("localhost", "root", "ld1224", "web_luntan_db"); 
mysqli_query($this->linkdb, "SET NAMES gbk"); 
} 
function __destruct() // 定 义 析 构 函 数 ， 关 闭 数据 库 连接 
{ 
mysqli_close($this->linkdb); 
} 
function exists($user) // 判 断 指定 用 户 是 否 存在 
Sresult = $this->linkdb->query("SELECT * FROM users WHERE userlD=" . $user .""); 
if($row = $result->fetch_row!()) 
{ 
Sthis->userlD = $user; 
Sthis->UserPwd = $row[1]; 
Sthis->UserName = $row[2]; 
return true; 
1 
else 
return false; 
function verify($user, $pwd) // 判 断 指定 的 用 户 名 和 密码 是 否 存 在 
{ 


$sql = "SELECT * FROM users WHERE userlD=" . $user . " AND UserPwd=" . $pwd . ”"; 
Sresult = $this->linkdb->query($sql); 
if($row = $result->fetch_row!()) 
上 
Sthis->userlD = $user; 
Sthis->UserPwd = $pwd; 
Sthis->UserName = $row[2]; 
return true; 
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} 
else 
return false; 
} 
function insert() // 插 入 新 用 户 记录 
{ 


$sql = "INSERT INTO users(userlD,UserPwd,UserName,registerTime) VALUES(" . $this-> 
userlD . ", " . $this->UserPwd .", " . $this->UserName . "," . $this->regsitertime . ") ; 
Sthis->linkdb->query($sq)l); 
} 
function updateShowName() 
{ 
$sql = "UPDATE users SET UserName=" . $this->UserName . ”WHERE userlD= ”. 
Sthis->userlD ."™™; 
Sthis->linkdb->query($sql); 
} 
function updatePassword() 
{ 
$sql = "UPDATE users SET UserPwd=" . $this->UserPwd . ”WHERE userlD=" . 
S$this->userlD ."™; 
$this->linkdb->query($sql); 


} 

function delete() 

1 
$sql = "DELETE FROM users WHERE userID=”. $this->userlD . ”"; 
Sthis->linkdb->query($sql); 

} 

function load_users() 

上 
$sql = "SELECT * FROM users"; 
Sresult = $this->linkdb->query($sql); 
Return $result; 

} 

YE 


11.3.2 ”留言 内 容 类 公用 模块 代码 的 设计 与 实现 


同样 ， 由 于 数据 库 web_luntan_db 中 的 留言 记录 表 〈Content) 在 整个 系统 运行 中 使 用 的 


频率 较 高 ， 因 此 可 定义 一 个 类 Content， 由 它 来 专门 负责 与 留言 内 容 相关 的 一 些 操作 。 该 类 
的 实现 代码 如 下 : 


<?PHP 

class Content 

{ 
var S$linkdb; 
public $Contld; 
public STitle; 
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public $Words; 
public $UserName; /留言 人 姓名 
public $Headface; // 头 像 图 标 
public $Email; // 电 子 邮 件 
public $Homepage; 
public $CreateTime:; /留言 时 间 
public $ParentTitlelD; /所 回复 的 留言 ID， 如果 不 是 回帖 ， 则 Upperld = 0 
function __construct() 
{ 


Sthis->linkdb = mysqli_connect("localhost", "root", "ld1224","web_luntan_db"); 
mysqli_query(S$this->linkdb, "SET NAMES gbk"); 


} 
function destruct() 
tt 
mysqli_close($this->linkdb); 
} 
function Fetchlnfo($ld) 
$sql = "SELECT * FROM Content WHERE Contld=" . $ld; 
Sresult = $this->linkdb->query($sql); 
if($row = $result->fetch_row!()) 
{ 
Sthis->Contld = $ld; 
Sthis->Title = $row[1]; 
Sthis->Words = $row[2]; 
Sthis->UserName = $row[3]; 
Sthis->Headface = $row[4]; 
Sthis->Email = $row[S]; 
Sthis->Homepage = $row[6]; 
Sthis->CreateTime = $row[7]; 
Sthis->ParentTitlelD = (int)$row[8]; 
1 
} 
function tbRowsCount() 
{ 
$sql = "SELECT COUNT(*) FROM Content"; 
Sresult = $this->linkdb->query($sql); 
if($row = $result->fetch_row!()) 
Return (int)$row[0]; 
else 
Return 0; 
} 
function insert() 
$sql = "INSERT INTO Content (Title, Words, UserName, Headface, Email Homepage, 
CreateTime, ParentTitlelD) VALUES(” . Sthis->Title . ", " . Sthis->Words . ", " . 
Sthis->UserName . ", " . $this->Headface .", ”. $this->Email . ", " . $this->Homepage .",". 
Sthis->CreateTime . ", " . $this->ParentTitlelD . ")"; 
Sthis->linkdb->query($sql); 
} 
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function delete($ld) 


{ 
$sql = "DELETE FROM Content WHERE Contld=" . $ld . " OR ParentTitlelD=" . $Id; 
Sthis->linkdb->query($sq)l); 

} 

function load_content_byUpperid($uid) 

{ 


$sql = "SELECT * FROM Content WHERE ParentTitlelD=" . $uid . ”ORDER BY 
CreateTime DESC"; 

Sresult = $this->linkdb->query($sql); 

Return $result; 


} 
function show_content_groupbyPage ($pageNo, $pageSize) // 分 页 显示 留言 内 容 
{ 


$sql = "SELECT * FROM Content ORDER BY CreateTime DESC LIMIT " . ($pageNo-1) 
* $pageSize ."," . $pageSize; 
Sresult = $this->linkdb->query($sql); 


Return $result; 


} 


Te 
11.3.3 “IP 地 址 类 公用 模块 代码 的 设计 与 实现 


该 类 主要 负责 对 参与 投票 的 计算 机 人 P 地 址 进行 处 理 ， 其 实现 代码 如 下 : 


<?PHP 

class VotelP 

1 
var Slinkdb; 
public $IPADRESS; 
function __construct() 


this->linkdb = mysqli_connect("localhost", "root", "ld1224", "web_luntan_db"); 
mysqli_query($this->linkdb, "SET NAMES gbk"); 
} 
function __destruct() 
mysqli_close($this->linkdb); 
} 
function exists($_IPAdress) // 判 断 指定 IP 是否 存 在 
{ 
result = S$this->linkdb->query("SELECT * FROM VotelP WHERE IPADRESS=" . 
$_IPAdress ."™"); 
if($row = $result->fetch_row!()) 
return true; 
else 
return false; 
} 
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function insert() // 插 入 新 记录 
{ 


$sql = "INSERT INTO VotelP VALUES("” . $this->IPADRESS . ")”; 
$this->linkdb->query($sql); 


} 
function deleteAll() /删除 所 有 的 投票 IP 
$sql = "DELETE FROM VotelP"; 
Sthis->linkdb->query($sql); 
} 
中 
ye 


11.3.4 用 户 验 证 公用 模块 代码 的 设计 与 实现 


该 公用 模块 主要 负责 验证 用 户 登录 系统 的 用 户 号 和 密码 是 否 正 确 ， 其 实现 代码 如 下 : 


<?PHP 

include('Baseclass\Users.php'); // 包 含 Users 类 
Suser = new Users(); 

session_start(); 

ifllisset($_SESSION[Passed])) 

{ 


$_SESSION[Passed'] = False; 


if($_SESSION['Passed]==False) 
{ 
// 读 取 从 表单 传递 过 来 的 用 户 号 和 用 户 密码 
S$userlD = $_POST[userID1]; 
S$UserPwd = $_POST['UserPwd'; 
if($userlD == "") 
$Errmsg = "请 输入 用 户 号 和 密码 "; 
else 
{ ”// 验 证 用 户 名 和 密码 
if(I$user->verify($userlD, $UserPwd)) { 


?> 
<script language="javascript"> 
alert(" 用 户 名 或 密码 不 正确 ); 
</script>"; 
<?PHP 


} 

else { // 登 录 成 功 ?> 
<script language="javascript"> 
alert(" 登 录 成 功 ""); 
</script> 

<?PHP 
$_SESSION[Passed] = True; 
$_SESSION['userlD'] = $userlD; 
$_SESSION[UserName'] = $user->UserName; 
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I/!$_SESSION[UserName'] = $row[2]; 


} 

if(I$_SESSION[Passed"]) { 

?> 
<script language="javascript"> 
history.go(-1); 
</script> 

<?PHP 

} 


?> 
11.3.5 ”保存 用 户 留言 公用 模块 代码 的 设计 与 实现 


该 公用 模块 主要 负责 对 用 户 的 留言 进行 保存 ， 其 实现 代码 如 下 : 


<?PHP 

include('Baseclass\Content.php ); 

$objContent = new Content(); 

/从 参数 或 表单 中 接收 数据 到 变量 中 
$objContent->UserName = $_POST["name"]; 
$objContent->Title = $_POST[Title"]; 
$objContent->Words = $_POSTI["Words"]; 
$objContent->Email = $_POST["email"]; 
SobjContent->Homepage = $_POST["homepage"]; 
SobjContent->Headface = $_POST["logo"]; 
SobjContent->ParentTitlelD = $_POST["ParentTitlelD"]; 
if($objContent->ParentTitlelD == ”) 
$objContent->ParentTitlelD = 0; 


// 获 取 当 前 时 间 

$now = getdate(); 

$objContent->CreateTime = $now[year] ."-" . $now[mon] ."-" . $now[mday].”“". $now['hours’] . 
":". Snow['minutes'] . ":" . $now['seconds']; 

SobjContent->insert(); 

echo("<h2> 信 息 已 成 功 保存 ! </h2>"); 

?> 


lf 


11.3.6 ”删除 用 户 留言 公用 模块 代码 的 设计 与 实现 


该 公用 模块 主要 负责 对 某 些 用 户 的 留言 进行 删除 ， 其 实现 代码 如 下 : 


<?PHP 
include(Yanzhengpw.php'); 
include('Baseclass\Content.php ); 
$Contld = (int)$_GET["Contld ]; 
S$objContent = new Content(); 
$objContent->delete($Contld); 
?> 
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11.4 各 功能 页 面 的 设计 及 代码 编写 


在 进行 系统 设计 和 程序 代码 编写 时 ， 可 选择 一 种 自己 比较 熟悉 且 好 用 的 PHP 代码 编辑 
器 来 进行 代码 设计 。 在 这 里 ， 建 议 使 用 Adobe Dreamweaver CS 系列 软件 ， 它 为 程序 员 提 供 
了 一 个 比较 友好 的 编程 环境 。 


11.4.1 网 站 首页 的 设计 与 实现 


首页 是 一 个 网 站 的 总 目录 ， 在 其 页 面 上 链接 了 所 有 的 信息 和 功能 页 面 。 本 网 络 留言 板 
的 首页 如 图 11-2 所 示 。 


标题 :很 好 时 间 : 2011-05-09 05:13:27 


冯 持 美国 反感 


标题 :不 见得 是 好 消息 。。 时间: 2011-05-08 04:09:53 


世界 不 一 定 就 太平 了 ， 兵 党 放 重 过 运 


标题 : 本 . 拉 辣 已 死 ， 世 界 真 的 蔬 安 全 了 吗 时 间 : 2011-05-08 04:08:01 


a 美国 糙 种 了 海防 翅 队 在 巴 其 斯 地 作 音 兰 全 避 区 击 线 了 基地 头目 拉 伏 ， 请 各 位 办 表 一 下 
法 


图 11-2 ”网络 留言 板 首页 
下 面 列 出 其 实现 的 程序 源 代码 ， 以 供 读者 学 习 参 考 。 


<script language="JavaScript"> 
function newwin(url) 
{ 
var newwin=window.open(url,"newwin","toolbar=no,location=no,directories=no,status=no, 
menubar =no, scrollbars=yes,resizable=yes,width=550,height=460"); 
newwin.focus(); 
return false; 
1 
</script> 
<style type="text/css"> 
alink{ text-decoration: none; color: #000000} 
</style> 
<?PHP 
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SuserlD = $_POST[userlD'; 


if($userlD = ”) 

include(Yanzhengpw.php"); // 包 含 验证 用 户 密码 程序 模块 Yanzhengpw.php 
include('Baseclass\Content.php'); // 包 含 留言 记录 程序 模块 Content.php 
include('Show.php'); // 包 含 显示 留言 内 容 的 程序 模块 Show.php 
S$objContent = new Content(); /定义 Content 对 象 ， 用 于 访问 表 Content 
$pageSize = 5; 


$pageNo = (int)$_GET[Page]; 
$recordCount = $objContent->TbRowsCount(); 
if($pageNo < 1) 
$pageNo = 1; 
if( $recordCount X{ 
if( $recordCount < $pageSize X{ 
S$pageCount = 1; 
} 
if( $recordCount % $pageSize \{ 
$pageCount = (int)($recordCount / $pageSize) + 1;} 
else{ 
S$pageCount = $recordCount / $pageSize; 


} 
} 
else{ 

$pageCount = 0; ”// 如 果 结 果 集 中 没有 记录 ， 则 页 数 为 0 
} 


if($pageNo > $pageCount) 
$pageNo = $pageCount; 
?> 
<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 网 络 留言 板 </title> 
</head> 
<body topmargin="0" vlink="#000000" link="#000000"> 
<div align="center"> 
<center> 
<table width="714" border="0" height="218" cellspacing="0" cellpadding="0"> 
<tr background="images/guangao.png > 
<td height="18" bordercolorlight="#0000FF" bordercolordark="#00FFFF" bgcolor="#3399FF" 
class="main"> 
<?PHP 
if(lI$_SESSION[Passed]) { 
?> 
<form method="POST" action="<?PHP $_SERVER[PHP_SELF] ?>" name="myform"> 
&nbsp;<font size="2"> 用 户 名 : </font><input type="text" name="userlD" size="12">&nbsp; 
&nbsp; 密码 : <input type="password" name="UserPwd" size="12"> <input type="submit" value= 
"登录 " name="B1"> 
<?PHP 


else{ 
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网 络 留言 板 


echo("<b> 欢 迎 管理 员 光 临 !</b>"); 
} 
?> 
[ <a target="_blank” href="newRec.php” onclick="return newwin(this.href)"> 我 要 留言 </a>][<a 
target="_blank"” href="register.php” onclick="return newwin(this.href)"> 用 户 注 册 </a>][<a 
target="_blank” href="Vote/Addltem.php” ”onclick="return newwin(this.href)"> 设 置 问卷 题目 
</a>][<a target="_blank" href="Vote/index.php” onclick="return newwin(this.href)"> 问 卷 调 查 </a>] 
<?PHP 
if($_SESSION['Passed"]) { 
echo('[<a href="logout.php"> 退 出 登录 </a>]); 
» 
ye 
</form> 
</tr> 
<tr> <td height="161" class="main"> <?PHP ShowList($pageNo, $pageSize); ?> </td></tr> 
<tr> <td height="15"> </td></tr> 
<tr> 
<td height="13" class="main" background="images/b3.gif’> <?PHP ShowPage($pageCount, 
SpageNo); ?></td> 
</tr> 
<tr> <td height="15"> <p align="center" class="main"></td></tr> 
</table> 
</body> 
?> 


用 户 登 录 系 统 成 功 后 ， 其 页 面 外 观 和 首页 类 似 ， 但 是 增加 了 回复 贴 子 和 删除 等 功能 ， 
其 页 面 效 果 如 图 11-3 所 示 。 


标题 :很 好 时 间 : 2011-05-09 05:13:27 


去 持 关 国 后 区 


标题 :不 见得 是 好 消息 。 时 间 ， 2011-05-08 04:09:53 


世界 不 一 证 就 太 王 了 ， 反 和 好 尾 看 道 和 


标题 :本 - 拉 生 已 死 ， 世 界 直 的 鼓 空 全 了 凤 。。 时 间 : 2011-05-08 04:08:01 


2 可 和 5 月， 基因 和 和 人 广陵 丰 巴 和 人 部 区 二 扫 了 基 地 大 有 位于 请 和 位 发表 下 
于 


图 11-3 登录 系统 成 功 后 的 主页 面 
其 实现 代码 (show.php 模块 ) 如 下 : 
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<head> 


<script language="JavaScript"> 
function newwin(url) 


{ 


var newwin=window.open(url,"newwin","toolbar=no,location=no, 
directories=no,status=no,menubar=no,scrollbars=yes,resizable=yes,width=550,height=460"); 
newwin.focus(); 

return false; 


} 


</script> 
</head> 
<?PHP 


function ShowList( $pageNo, $pageSize ) { 


?> 


<div align="center"> 

<center> 

<table border="1" width="738” bordercolor="#3399FF" cellspacing="0" cellpadding="0" 
height= "46" bordercolorlight="#FFCCFF" bordercolordark="#CCCCFF"> 

<?PHP 

SexistRecord = False; 

S$objContent = new Content(); 

Sresults = $objContent->show_content_groupbyPage($pageNo, $pageSize); 

// 使 用 while 语句 遍历 $results 中 的 留言 数据 

while($row = $results->fetch_row()) { 


$existRecord = True; 

?> <tr> 

<td width="148" height="16" class="main" align=center> <br> 

<img border="0" src="images/<?PHP echo($row[4]); ?>.gif” width="100” height= 


"100"><br> 


/></a> 


<?PHP echo($row[3]); ?><br><br> 
<a href="<?PHP echo($row[6]); ?>" target=_blank> 
<img border="0" src="images/homepage.gif" width="16" height="16"></a> 
<a href="mailto:<?PHP echo($row[S5]); ?>"> 
<img border="0" src="images/email.gif" width="16" height="16"></a><br> 
<?PHP if($_SESSION["userlD"] <> ) {?> 
<a href=newRec.php?ParentTitlelD=<?PHP echo($row[0]); ?> 
target=_blank onclick="return newwin(this.href)"><img src= "images/reply.gif /> </a> 
<a href=deleteRec.php?Contld=<?PHP echo($row[0]); ?> 
target=_blank onclick ="return newwin (this.href)"><img src="images/delete.GIF" 


<?PHP } ?> 
</td> 
<td width="584" height="16” class="main” align="left” valign="top"><br><b> 标 


题 :<?PHP echo ($row[1]); ?> &nbsp;&nbsp;&nbsp; 时 间 : <?PHP echo($rowf7]); ?></b><hr><br> 


-=P 

echo($row[2]); 

/显示 所 有 回复 留言 

S$content = new Content(); /定义 Content 对 象 
$sub_results = $content->load_content_byUpperid($row[0]); 
while($subrow = $sub_results->fetch_row()) { 
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echo("<BR><BR><BR>"); ?>&nbsp;&nbsp;&nbsp; 

<img border="0" src="images/<?PHP echo($subrow[4]); ?>.gif" width="50" height="50"> 
<?PHP echo($subrow[3]); ?> 

<a href="<?PHP echo($subrow[6]); ?>" target=_blank> 

<img border="0" src="images/homepage.gif" width="16" height="16"></a> 

<a href="mailto:<?PHP echo($subrow[5]); ?>"> 

<img border="0” src="images/email.gif” width="16” height="16"></a>&nbsp;&nbsp; 


&nbsp; 


<b>&nbsp;&nbsp;&nbsp; 标题 :<?PHP echo($subrow[1]); ?> &nbsp;&nbsp;&nbsp; 时 


间 : <?PHP echo($subrow[7]);?></b><hr><br> 


} 


Ps 


&nbsp;&nbsp;&nbsp; <?PHP echo($subrow[2]); ?> 
<?PHP 
| 


?> 
</td> 
</tr> 
<?PHP 


1 
if(I$existRecord) { 
?> 
<tr> 
<td width="148" height="16" align=center class="main"> 没 有 留言 数据 </td> 
</tr> 
<?PHP 


echo("</table></center></div>"); 


<?PHP 
function ShowPage( $pageCount, $pageNo ) 


{ 


echo("<table width=738> <tr> <td align=right class=main>"); 
if($pageNo>1) 
echo("<A HREF=index.php?Page=1> 第 一 页 </A>&nbsp;&nbsp;"); 
else 
echo(" 第 一 页 &nbsp;&nbsp;"); 
if($pageNo>1) 
echo("<A HREF=index.php?Page=" . ($pageNo-1) . "> 上 一 页 </A>&nbsp;&nbsp;"); 
else 
echo(" 上 一 页 &nbsp;&nbsp;"); 
if($pageNo<>$pageCount) 
echo("<A HREF=index.php?Page=" . ($pageNo+1) . "> 下 一 页 </A>&nbsp;&nbsp;"); 
else 
echo(" 下 一 页 &nbsp;&nbsp;"); 
if($pageNo <> $pageCount) 
echo("<A HREF=index.php?Page=" . $pageCount . "> 最 后 一 页 </A>&nbsp;&nbsp;"); 
else 
echo(" 最 后 一 页 &nbsp;&nbsp;"); 
echo($pageNo . "/" . $pageCount . "</td></tr></table>"); 
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11.4.2 用户 注 册页 面 的 设计 与 实现 


用 户 注册 页 面 的 主要 作用 是 采集 各 用 户 的 主要 信息 〈 如 用 户 真 实 姓 名 、 性 别 、 职 业 和 


联系 方式 等 ) ， 以 方便 网 站 的 维护 和 管理 ， 同 时 也 方便 不 同人 员 之 间 的 联系 。 本 系统 的 注 
册页 面 如 图 11-4 所 示 。 
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图 11-4 网 络 留言 板 的 新 用 户 注册 页 面 
下 面 列 出 其 实现 的 程序 源 代码 ， 以 供 读 者 学 习 参 考 。 


<html> 
<head><meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title> 网 络 留言 板 </title> 
<link href="inc/style.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<?php 
include(Show.php'); 
include('Baseclass\Content.php ); 
include('Baseclass\Users.php'); 
$bb=new Users; 
?> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="73%" height="30"><a href="./"> 网 络 留言 板 </a>>> 新 用 户 注册 </td> 
<td width="27%" align="right" valign="middle"><a href="new_note.php"></a></td> 
</tr> 
</table> 
<table width="98%" border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#FFFFFF"> 
<tr> 
<td height="25" align="center" valign="middle" bgcolor="5F8AC5"> 新 用 户 信息 </td> 
</tr> 
<tr> 
<td height="25" align="center valign="middle"> 
<?php 
Stijiao=$_POSTI[tijiao]; 
if ($tijiao==" 提 交 "X{ 
S$userlD=$_POST[userlD]; 
/l/$query="select * from users where userlD='$userlD"™; 
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if ($bb->exists($userlD)){ 
echo "=== 该 用 户 名 已 经 存在 ， 请 设置 其 他 用 户 名 ! ==="; 
} 
else{ 
$bb->userlD=$userlD; 
$bb->UserPwd=$_POST[user_pw1]; 
$bb->UserName=$_POST[UserName]; 
S$bb->regsitertime=date("Y-m-d H:i:s"); 
if ($user_pw1!=$user_pw2){ 
echo "=== 您 两 次 输入 的 密码 不 匹配 ， 请 重新 输入 ! ==="; 
} 
else 
{ 
$bb->insert(); 
echo "注册 成 功 ! 请 <a href=index.php/> 返 回 主页 后 重新 </a> 登 录 "; 
Sregister_tag=1; 


J 

y 
if ($register_tag!=1){ 
?> 
<form name="form1" method="post" action="#"> 
<table width="500" border="0" cellpadding="0" cellspacing="2"> 

<tr> 

<td width="122" height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 用 户 号 :</td> 

<td width="372” height="26" align="left” valign="middle"” bgcolor="#CCCCCC"><input 

type="text" name="userlD"></td> 
</tr> 

<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 用 户 名 :</td> 
<td height="26" align="left” valign="middle” bgcolor="#CCCCCC"><input type="text" name= 
"UserName"></td> </tr> 
<tr> 
<td height="26" align="right” valign="middle”bgcolor="#CCCCCC"> 密 码 :</td><td height="26" 
align="left" valign="middle" bgcolor="#CCCCCC"><input type="text" name="user_pw1"></td> 
</tr> 
<tr> 
<td height="26" align="right" valign="middle" bgcolor="#CCCCCC"> 重 复 密码 :</td> 
<td height="26" align="left” valign="middle” bgcolor="#CCCCCC"><input type="text” name= 
"User_pw2"></td> 
</tr> 
<tr> 
<td height="26" colspan="2" align="center" valign="middle" bgcolor="#CCCCCC"><input type= 
"submit" name="tijiao" value=" 提 交 ">&nbsp;&nbsp;&nbsp;&nbsp;<input type="reset" name="Submit2" 
value=" 重 置 "></td> 
</tr> 
</table></form> 
<?php 
) 
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入 全 

</td> </tr> 

<tr> 

<td height="1" bgcolor="#CCCCCC"></td> 
</tr> 

</table></body> 

</html> 


11.4.3 ”添加 新 留言 页 面 的 设计 与 实现 


用 户 可 以 通过 如 图 11-5 所 示 的 页 面 来 发 布 留 言 信息 。 其 中 ， 用 户 姓 名 、 留 言 标 题 和 留 
言 内 容 是 必 填 项 目 。 


添加 新 留言 (* 为 必 填 项 ) 


图 11-5 添加 新 留言 页 面 
11.4.4 问卷 调查 内 容 设置 功能 页 面 的 设计 与 实现 


网 络 留言 本 的 管理 员 还 可 以 通过 网 页 对 某 件 事 进行 问卷 调查 。 首先 要 通过 如 图 11-6 所 示 
的 页 面 来 添加 和 编辑 调查 内 容 及 选项 , 在 该 页 面 中 还 可 以 对 已 有 选项 进行 修改 、 删 除 等 操作 。 
[DIEIETT 


问卷 调查 投票 选项 管理 


最 佳 用 户 是 :aa 
景 佳 用 户 是 :bb 
最 佳 用 户 是 :cc 
最 佳 用 户 是 :dd 


清空 划 禾 ， 重 新 投票 、 计 票 国光 | 时 到 加 院 | 
| 


了 出 局 阿 攻 | tret ET 


图 11-6 问卷 调查 内 容 设置 功能 页 面 
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下 面 列 出 其 实现 的 程序 源 代码 ， 以 供 读者 学 习 参 考 。 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<title> 问 卷 调 查 投票 </title> 
<link rel="stylesheet" href="style.css"> 
</head> 
<script language="JavaScript"> 
function newwin(url) { 
var oth="toolbar=no,location=no,directories=no,status=no,menubar=no,scrollbars=yes, 
resizable=yes,left=200,top=200"; 
oth = oth+",width=200,height=100"; 
var newwin=window.open(url,"newwin",oth); 
newwin.focus(); 


return false; 
} 
function SelectChk() 
{ 

var s=false; 


var itemid,n=0; 

var strid, strurl; 

var nn = self.document.all.item("dept"); 
for (j=0;j<nn.length-1;j++) 


{ 
if (self.document.all.item("dept",j).checked) 
{ 
n=n+1; 
s=true; 
itemid = self.document.all.item("dept j).id+”; 
if(n==1) 
{ 
strid = itemid; 
| 
else 
{ 
strid = strid + "," + itemid; 
} 
alert(strid); 
} 
} 
strurl = "Addltem.php?Oper=delete&id=" + strid; 
if(!s) 
{ 
alert(" 请 选择 要 删除 的 投票 选项 !"); 
return false; 
} 
if ( confirm(" 你 确定 要 删除 这 些 投票 选项 吗 ? ") 
{ 


form1.action = strurl; 
form1.submit(); 
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} 
} 
function sltAll() 
{ 
var nn = self.document.all.item("dept"); 
for(j=0;j<nn.length;j++) 
{ 
self.document.all.item("dept",j).checked = true; 
} 
} 
function sltNull() 
ii 
var nn = self.document.all.item("dept"); 
for(j=0;j<nn.length;j++) 
self.document.all.item("dept",j).checked = false; 
} 
nl 
</script> 


<body link="#000080" vlink="#080080"> 

<form id="form1" name="form1" method="POST"> 
<?PHP 

$Soperate = $_GET["Oper"]; 
include("Baseclass\Voteltem.php ); 


$obj = new Selectltem(); /定义 新 对 象 
$Operid = $_GET["'id"]; // 选 项 编号 
if($Soperate=="add") { // 添 加 选项 

SnewTitle = $_POSTT["txttitle"]; 

echo($newTitle); 

1/ 判断 数据 库 中 是 否 存在 此 类 别 


if($0bj->exists($SnewTitle)) 

echo(" 已 经 存在 此 投票 选项 ,添加 失败 六); 
else{ 

S$obj->ltem = $newTitle; 

$obj->insert(); 

echo(" 投 票选 项 已 经 成 功 添加 ""); 
} 


elseif($Soperate == "edit) { 
SnewTitle =$_POSTT'txttitle ]; 
S$orgTitle = $_POST["sOrgTitle"]; 
echo("newTitle : " . $newTitle ." orgTitle: ". $orgTitle); 
if($newTitle<>$orgTitle) { 
if($obj->exists($newTitle)) 
echo(" 已 经 存在 此 投票 选项 ,添加 失败 六 ); 
else{ 
S$obj->updateltem($newTitle, SOperid); 
echo(" 投 票选 项 已 经 成 功 修改 ""); 
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} 
} 
elseif($Soperate=="delete") { 
S$obj->delete($Operid); 
echo(" 投 票选 项 已 经 成 功 删除 ""); 
} 
?> 
<p align="center" class="STYLE1"><font style="FONT-SIZE: 12pt"> 问 卷 调查 投票 选项 管理 </font></p> 
<center> 
<table border="1" cellspacing="0" width="90%" bordercolorlight="#4DA6FF" bordercolordark= 
"#ECFSFF" style="FONT-SIZE: 9pt"> 
<tr> 
<td width="60%" align="center" bgcolor="#FEEC85"><strong> 选 项 </strong></td> 
<td width="20%" align="center" bgcolor="#FEEC85"><strong> 修 改 </strong></td> 
<td width="20%" align="center" bgcolor="#FEEC85"><strong> 选 择 </strong></td> 
</tr> 
<?PHP 
ShasData = false; 
Sresults = $obj->load_Voteltem(); 
while($row = $results->fetch_row()) { 
$hasData = true; 
?> 
<tr><td> <?PHP echo($row[1]);?> </td> 
<td align="center"><a href="Addltem.php?Oper=update&id=<?PHP echo($row[0]);?>&name= 
<?PHP echo($row[1]); ?>"> 修 改 </a></td> 
<td align="center"><input type="checkbox" name="dept" id=<?PHP echo($row[0]); ?>></td> 
</tr> 
<?PHP 
b 
if(l$hasData) { 
?> 
<tr><td colspan=3 align=center><font style="COLOR:Red"> 目 前 还 没有 投票 选项 。</font> 
</td></tr></table> 
<?PHP} ?> 


</table> 
<p align="center"> 
<input type="button”name="revote”value=" 清 空 票数 ， 重 新 投票 、 计 票 "onClick="return 
newwin (‘ReVote.php')"> &nbsp;&nbsp; 
<?PHP 
if($hasData) { 
?> 
<input type="button" value=" 全 选 " onClick="sItAll()"> 
&nbsp;&nbsp;<input type="button" value=" 清 空 " onClick="sltNull()"> 
&nbsp;&nbsp;<input type="submit" value=" 删 除 " name="tijiao" onClick="SelectChk()"> 
<?PHP 
} 
?> 
</form> 
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<?PHP 
if($Soperate == "update") 
{ 
SsTitle =$_GET["name'"]; 
?> 
<form name="UFrom" method="post" action="Addltem.php?id=<?PHP echo($Operid); ?>&Oper 
=edit"> 
<div align="center > 
<input type="hidden" name="sOrgTitle" value="<?PHP echo($sTitle); ?>"><font color= 
只 FFFFFF"><b><font color='"#000000"> 投 票选 项 名 称 </font></b></font> 
<input type="text" name="txttitle" size="20" value="<?PHP echo($sTitle); ?>"> 
<input type="submit" name="Submit" value=" 修 改 "> 


</div> 
</form> 
<?PHP 
} 
else{ 
入 


<form name="AForm" method="post" action="Addltem.php?Oper=add"> 
<div align="center"> 
<font color="#FFFFFF"><b><font color='"#000000"> 投 票选 项 名 称 </font></b></font> 
<input type="text" name="txttitle" size="20"> 
<input type="submit" name="Submit" value=" 添 加 "> 
</div> 
</form> 
<?PHP 
} ?> 
<input type="hidden" name="dept"> 
</BODY> 
</HTML> 


11.4.5 网络 投票 页 面 的 设计 与 实现 


通过 网 络 投票 进行 某 件 事 的 调查 ， 是 现代 互联 网 的 重要 应 用 之 一 。 它 可 以 大 大 降低 传 


统 调查 方式 的 运行 成 本 ， 节 省 时 间 ， 提 高 工作 效率 ， 而 且 还 可 以 提高 调查 的 准确 度 。 该 页 


面 的 运行 效果 如 图 11-7 所 示 。 
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候选 人 ( 修 认 为 本 网 站 哪个 用 户 最 佳 》 
最 佳 用 户 是 :aa 
最 佳 用 户 是 :bb 
最 佳 用 户 是 : cc 


景 佳 用 户 是 :dd 
投票 


| 国 Internet ET 


图 11-7 网 络 投票 页 面 
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其 实现 的 程序 代码 如 下 : 


<?PHP 
S$ip = $_SERVER['"REMOTE_ADDR"]; 
include('Baseclass\VotelP.php’); 
$objlP = new VotelP(); 
// 如 果 表 中 没有 投 过 票 ， 则 插入 记录 
if($objlP->exists($ip)) { 
echo(" 你 已 经 投 过 票 了 ， 不 得 重复 投票 !"); 
} 
else{ 
$objlP->IPAdress = $ip; 
$objlP->insert(); 
$ids = $_GET["cid"]; 


<?PHP 
class Selectltem 
{ 
var $linkdb; 
public $ld; 
public $ltem; // 选 项 名 称 
public $VoteCount:; /投票 数量 ， 默 认为 0 
function __construct() 
{ 
Sthis->linkdb = mysqli_connect("localhost", "root", "ld1224", "web_luntan_db"); 
mysqli_query(S$this->linkdb, "SET NAMES gbk"); 
} 
function _ destruct() 
{ 
mysqli_close($this->linkdb); 
0 
function exists(S$title) // 判 断 选项 是 否 存 在 
{ 
$sql = "SELECT * FROM Selectltem WHERE ltem=" . $title . ”"; 
Sresult = $this->linkdb->query($sql); 
if($row = $result->fetch_row!()) 
Return true; 
else 
Return false; 
} 
function Fetchlnfo($ld) // 获 取 选 项 的 内 容 
四 


$sql = "SELECT * FROM Selectltem WHERE |d=" . $ld; 
Sresult = $this->linkdb->query($sql); 
if($row = $result->fetch_row!()) 


u 
Sthis->ld = $ld; 
Sthis->ltem = $row[1]; 
S$this->VoteCount = (int)$row[2]; 
} 
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} 
function insert() /插入 新 记录 
$sql = "INSERT INTO Selectltem (ltem, VoteCount) VALUES("”. $this->ltem . ", 0)"; 

Sthis->linkdb->query($sq)l); 

bh 

function delete($lds) 

1 
$sql = "DELETE FROM Selectltem WHERE Id IN (". $lds . ")"; 
Sthis->linkdb->query($sql); 

} 


function updateltem($newltem, $id) { 
$sql = "UPDATE Selectltem SET ltem=" . $newltem . " WHERE Id=" . $id; 
Sthis->linkdb->query($sql); 
1 
function clearCount() { 
$sql = "UPDATE Selectltem Set VoteCount=0 WHERE Id>0"; 
Sthis->linkdb->query($sql); 
1 
function getltemCount() { 
$sql = "SELECT Count(*) FROM Selectltem"; 
Sresults = $this->linkdb->query($sql); 
if($row = $results->fetch_row()) 
Return (int)$row[O]; 
else 
Return 0; 
b 
function SumltemCount() { 
$sql = "SELECT Sum(VoteCount) FROM Selectltem"; 
Sresults = $this->linkdb->query($sql); 
if($row = $results->fetch_row()) 
Return (int)$row[0]; 
else 
Return 0; 
1 
function updateCount($lds){ 
$sql = "UPDATE Selectltem SET VoteCount=VoteCount+1 WHERE Id IN (". $lds .")"; 
$this->linkdb->query($sql); 


b 

function load_Selectltem() 

{ 
$sql = "SELECT * FROM Selectltem"; 
Sresults = $this->linkdb->query($sql); 
Return $results; 

} 


} 


> 
$objltem = new Selectltem(); 
$objltem->updateCount($ids); 
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echo(" 已 成 功 投票 "); 
} 


?> 

<script language=javascript> 
setTimeout("window.close()",800); 
opener.location.reload(); 

</script> 


11.4.6 ”网 络 投票 结果 查询 页 面 的 设计 与 实现 


在 网 络 投票 进行 过 程 中 ， 用 户 还 可 以 实时 查看 投票 结果 ， 其 运行 结果 如 图 11-8 所 示 。 


66.6565656567% 
0% 


| 


图 11-8 投票 结果 查询 


其 实现 的 程序 代码 如 下 : 


<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
<link href="style.css" type="text/css" rel=stylesheet> 
<title> 投 票 系统 </title> 
</head> 
<body topmargin="2" leftmargin="2"> 
<form method=post id="form1"><center> 
<table border="0" width="98%" cellpadding="0" cellspacing="4"> 
<tr> 
<td width="100%"> 
<table border="0" width="100%" cellspacing="0" cellpadding="0" style="background-color: 
#BODCFO;border: 1 dotted #A7D8EF"> 
<tr> 
<td width="100%"> 
<table border="0" width="100%" cellspacing="1" cellpadding="3"> 
<tr> 
<td bgcolor="#FFFFFF" valign="top"> 
<table border="0" width="100%" cellspacing="1" style="background-color:#BODCFO; 
border: 1 dotted #A7D8EF"> 
<tr> 

<td width="40%"> 投 票选 项 </td> 

<td width="40%" colspan="2"> 支 持 率 </td> 

<td width="10%"> 票 数 </td> 
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</tr> 

<?PHP 
include('Baseclass\Voteltem.php ); 
Sobijltem = new Selectltem(); 
Stotal = $objltem->SumltemCount(); 
Sresults = $objltem->load_Selectltem(); 
while($row = $results->fetch_row()) { 
if($total == 0) 

Sitotal = 1; 
else 

Sitotal = S$total; 


Simgvote = (int)$row[2] * 170 / Sitotal; 
?> 
<tr><td bgcolor="#FFFFFF"><?PHP echo($row[1]);?></td> 
<td colspan="2" bgcolor="#FFFFFF"> 
<img src=images/bar1.gif width=<?PHP echo($imgvote); ?> height=10><font style= 
"font:7pt" face="Verdana"> 
<?PHP echo((int)$row[2]*100/$itotal); ?>%</font></td> 
<td bgcolor="#FFFFFF" align="center"><?PHP echo($row[2]); ?></td> 
</tr> 
<?PHP }?> 
<tr> <td colspan="2" align="left"></td> 
<td colspan="2" align="right"> 总 票数 : <?PHP echo($total); ?></td> 
</tr> 
</table> 
</td> 
</tr> 
</table> 
</td> 
</tr> 
</table> 
</td> 
</tr> 
</table> 
</center> 
<input type=hidden name="poster"> 
</form><body> 
<script language=javascript> 
opener.location.reload(); 
</script></html> 


11.5 本 章 小结 


随 着 互联 网 应 用 的 普及 ， 人 们 越发 希望 可 以 不 安装 其 他 任何 软件 ， 只 通过 浏览 器 便 能 
实现 对 某 个 信息 系统 的 各 种 操作 ， 享 受信 息 服 务 。 利 用 PHP 技术 来 实现 B/S 模式 的 信息 管 
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理 系 统 正 被 越 来 越 多 的 程序 员 所 追捧 。 本 章 通过 详尽 的 实例 ， 系 统 阐述 了 在 PHP 中 实现 信 
息 系统 开发 过 程 中 所 需 的 步骤 。 另 外 ， 通 过 本 实例 ， 读 者 还 应 仔细 体会 在 PHP 程序 中 ， 利 
用 面向 对 象 编程 技术 实现 项 目的 模块 化 开发 的 优点 。 


11.6 练 习 题 


1. 在 PHP 程序 中 如 何 实现 MySQL 数据 库 的 连接 ? 

2. 根据 个 人 的 理解 ， 你 认为 设计 一 个 数据 库 需 要 经 过 哪些 步骤 ? 

3. 通过 本 章 的 学 习 ， 总 结 一 下 常用 的 数据 库 操作 函数 种 类 及 各 自 的 用 法 。 

4. 试 编写 一 个 名 为 DB_Link 的 类 ， 在 类 中 要 求实 现 当 对 该 类 的 对 象 进行 调用 时 ， 自 
动 连接 数据 库 ， 而 释放 该 对 象 时 ， 自 动 断 开 数 据 库 连 接 。 


11.7 上 机 实战 


请 用 PHP 语言 设计 一 个 学 生成 绩 管理 系统 的 成 绩 输入 子 系统 ， 要 求 能 实现 以 下 功能 
通过 Web 浏览 器 ， 在 设计 好 的 页 面 内 输入 学 号 (CHAR(10)) 、 课 程 编号 (CHAR(10)) 和 
成 绩 (TINYINT)， 旦 在 输入 成 绩 时 ， 如 果 成 绩 小 于 60， 则 在 页 面 内 立即 用 红色 显示 该 成 
绩 ， 成 绩 输入 完毕 后 ， 通 过 单 击 页 面 上 的 提交 按钮 ， 可 以 将 批量 成 绩 数据 一 次 性 提交 并 保 
存 到 后 台数 据 库 的 成 绩 表 中 。 


第 12 童 实验 指导 


掌握 PHP+MYSQL+Apache 开发 环境 的 配置 
回 了 解 PHP Web 项 目 开发 的 一 般 流 程 

回 数据库 系统 设计 

数据 库 系 统 的 定义 及 使 用 

回 PHP 程序 中 灵活 高 效 地 使 用 MySQL 数据 库 


本 章 导读 : 


在 PHP 动态 网 站 设计 中 ， 数 据 库 技术 是 必 不 可 少 的 组 成 部 分 。PHP+MYSQL+Apache 是 
Web 项 目 开发 最 常见 的 组 合 之 一 ， 也 是 理论 和 实际 联系 的 非常 紧密 的 一 项 技术 ， 因 此 ， 上 
机 实验 就 成 了 教学 和 学 习 过 程 中 的 必要 环节 。 本 章 对 如 何 选 择 及 配置 实验 环境 、 数 据 库 系 
统 设计 与 应 用 进行 阐述 ， 然 后 通过 两 个 具体 实例 来 说 明 Web 项 目 开发 的 一 般 步骤 ,希望 读 
者 阅读 后 能 有 一 定 的 受益 。 


12.1 PHP+MySQL+Apache 系统 开发 平台 的 配置 


在 第 1 章 中 详细 讲述 了 如 何 配置 PHP+Apache 的 Web 程序 开发 环境 , 在 第 6 章 中 讲述 
了 怎样 安装 和 使 用 MySQL 数据库 。 除 此 之 外 ， 其 实 还 有 更 简洁 方便 的 配置 方法 ， 这 就 是 由 
网 站 www.appservnetwork.com 免费 提供 的 PHP+MySQL+Apache 集成 开发 环境 的 配置 软件 
AppServ。 下 面 将 介绍 如 何 利用 该 软件 配置 程序 员 所 需要 的 软件 环境 。 


12.1.1 下 载 AppServ 软件 


AppServ 软件 可 在 大 约 1 分 钟 内 将 Apache 服务 器 、PHP、MySQL 数据 库 环 境 安装 配 
置 好 , 同时 还 集成 有 phpMyAdmin 以 便 用 户 管理 数据 库 。 在 利用 AppServ 软件 安装 配置 PHP 
程序 开发 环境 之 前 ， 先 要 到 网 上 下 载 AppServ 软件 包 。 

很 多 网 站 都 提供 了 免费 下 载 AppServ 软件 包 服务 ， 但 为 了 软件 的 安全 性 ， 建 议 到 官方 
网 站 www.appservnetwork.com 下 载 ， 其 步骤 如 下 : 

(1) 在 浏览 器 地 址 栏 中 输入 “www.appservnetwork.com”， 然 后 按 Enter 键 后 进入 
AppServ 软件 的 官方 主页 ， 如 图 12-1 所 示 。 

(2) 在 该 页 面 中 查找 所 需要 安装 的 AppServ 版 本 。 一 般 来 说 ， 网 站 会 将 最 新 版 本 突出 
显示 在 网 页 首部 。 图 12-1 中 显示 了 AppServ 的 最 新 版 本 为 2.5.10， 在 这 里 ， 不 妨 选择 该 版 
本 ， 然 后 单 击 图 12-1 中 用 和 矩形 框 圈 住 部 分 的 链接 地 址 : 
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http://prdownloads.sourceforge.net/appserv/appserv-win32-2.5.10.exe?download 
随后 即 可 将 该 软件 包 下 载 到 本 地 ， 如 图 12-2 所 示 。 


oI] 
ET TE | 二 
Bm :OTP Ew|D XOXND ” 
Main Menu AppServ 2.5.10 and 2.6.0 with PHPS New Released 1 [1 EL 
由 出 者 启 spples 扒 Szturcay, May 10 因 00:59:41 M7 


What sappserv 


文件 和 从 天 全 
Howto ntoll AppSer Appser 2.5.10 
a 是 14 
ee Spe 和 和 TY 
DevelperT ， 而 si 
ed » phoMWAdnn2.103 bd 罗兰 
Downioad Wow 


Version History 


Downioad 加 大 2 
ER TS Se 
NEWS Archve downbac 了 FF a ndows 下 通过 
< EE 
y 


三 三 厂 厚 厂 厂 科 trent DWAR 4 


图 12-1 AppServ 官方 网 站 首页 图 12-2 下 载 到 本 地 的 AppServ 安装 软件 包 
12.1.2 安装 AppServ 软件 


下 载 AppServ 软件 包 到 本 地 计算 机 后 ， 即 可 进行 安装 ， 其 具体 步骤 如 下 : 

(1) 双击 AppServ 安装 程序 appserv-win32-2.5.10.exe， 出 现 如 图 12-3 所 示 的 欢迎 界面 。 

(2) 单 击 Next 按钮 ， 进 入 如 图 12-4 所 示 的 软件 安装 的 许可 协议 界面 ， 单 击 接受 许可 
协议 按钮 “I Agree”。 


Welcome to the AppServ 2.5.10 
Setup Wizard 


DE eand wh gue youthrogh the natalation of Popsery 


recommended that you close all other applcations 
be nt ebp ee Updake 
relevant system fies without having to re 
computer 


GNU LESSER GENERAL PUBLIC LICENSE 
Yersion 2.1, February 1999 


Copyrihe (C) 4991, 1999 Free Software Pond 
te 330, 


Chck Next to continue, 


p: 
bye 
[= 
a 
& 
吕 
9 
©. 


J you exeept the terms of the ogreement, chkT Aoree to contrue You must ocrept the 
geement to nstal AppServ 2.5.10. 


WE ET ] ce | 
图 12-3 ”AppServ 欢迎 界面 图 12-4 AppServ 软件 安装 许可 协议 


(3) 弹出 如 图 12-5 所 示 的 选择 软件 安装 位 置 的 对 话 框 ， 用 户 根 据 自己 实际 需要 进行 

(4) 单 击 Next 按钮 ， 出 现 如 图 12-6 所 示 的 选择 安装 组 件 对 话 框 , 在 此 选择 所 有 组 件 ， 
即 Apache 服务 器 、MySQL 数据 库 、PHP 预 处 理 器 以 及 phpMyAdmin 数据 库 管理 软件 。 

(5) 单 击 Next 按钮 ， 出 现 如 图 12-7 所 示 的 Apache HTTP 服务 器 配置 对 话 框 ， 要 求 用 
户 设置 服务 器 名 称 、 管 理 员 的 邮箱 地 址 和 Apache 服务 器 的 HTTP 服务 端口 号 (Apach HTTP 
Port) ， 其 默认 值 为 80， 在 这 里 选择 此 默认 值 。 
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(6) 单 击 Next 按钮 ， 出 现 如 图 12-8 所 示 的 MySQL 数据 库 服 务 器 配置 对 话 框 ， 要 求 
设置 系统 管理 员 用 户 “root” 的 密码 以 及 MySQL 数据 库 的 字符 集 设 置 ， 对 于 中 国 大 陆地 区 
的 用 户 来 说 ， 选 择 简体 中 文字 符 集 (GB2312 Simplified Chinese) 即 可 。 

区 wpsery 2.5. 10 set El| Be 


Choose Install Location 
Choose the folder in which to nstal AppServ 2.5.10， 


Select Components 
Select the components you want toinstall clear the components 
You do not want to instal, 


folowing folder, To install n a different Folder, cick 


Space required; 56.4MB 
Space avalable; 3.8GB 


Mulsoft Instal System v2-1€ 


=I5)x 
WN MySQL Server Configuration 
Configure the MySQL Server nstance， 


Apache HTTP Server Information 
Please enker your server's nformation. 
MuSQL 


Server Name (e.g, www,appservnetwork com) 
hocahost 

Administrator’s Emal Address (e.9. webmasterggmalcom) 
pmaieeccom 

Apache HTTP Port (Defauk :80) 


厂 od Password Support (PHP MYSQL API function,) 
厂 Enable ImopDe 


Nullsoft Instal sytem va,1B 


Carel 
图 12-7 Apache HTTP 服务 器 配置 对 话 框 图 12-8 ”MySQL 数据 库 服 务 器 配置 对 话 框 
(7) 单 击 Install 按钮 ， 系 统 将 开始 执行 安装 AppServ， 如 图 12-9 所 示 。 


图 12-9 开始 安装 AppServ 
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(8) 待 安装 进度 条 完毕 后 ， 此 时 灰色 的 Next 按钮 将 显示 为 黑色 字体 ， 表 示 可 用 ， 单 
击 Next 按钮 ， 弹 出 如 图 12-10 所 示 的 对 话 框 ， 用 户 可 从 此 对 话 框 中 选择 立即 启动 Apache 
服务 器 和 MySQL 数据 库 服务 器 ， 然 后 单 击 Finish 按钮 ， 至 此 AppServ 安装 完毕 。 


2.5.10 Setap 


Completing the AppServy 2.5.10 
Setup Wizard 


AppServ 2.5.10 has been instaled on your computer. 
Cick Finish to dose this wizard, 


WS Beart Apache] 


Ft Start My5QL 


图 12-10 ”安装 完成 AppServ 


下 面 讲解 如 何 验 证 PHP+MySQL+Apache 开发 环境 是 否 配置 成 功 。 
打开 网 页 浏览 器 ， 在 地 址 栏 中 输入 “http://localhost”， 按 Enter 键 后 ， 如 果 出 现 如 
图 12-11 所 示 的 页 面 ， 则 说 明 PHP+MySQL+Apache 开发 环境 配置 成 功 。 


[AprSerr Open Project 2 5.10 ~ Windons Interael Lpl 


GO |e) Mp://ocdhost/ 
」 文件 中。 编 竹 到 ) 查看 WD 收藏 天 () 工具 GD) 帮助 
该 收 蕊 天 。 十 Appserv 0pen Projeet 2.5.10 


The AppServ Open Project - 2.5.10 for Windows 


站 phpMyAdmin Database Manager Version 2.10.3 
2) PHP Information Version 5.2.6 


AboutAppServ Version 25.10 for Windows 


AppServ is a merging open source sofware installer package for Windows includes 


» Apache Web ServerVersion 2.2.8 
。 PHP Script Language Version 5.2.6 

» MySQL Database Version 5.0.51b 

» phpMyAdmin Database Manager Version 2.10.3 


» ChangeLog 

» README 

» AUTHORS 

se COPYING 

» Official Site : htp/ww AppServNetwork com 

» Hosting support by : htip://www AppServHosting com 


Change Language : ns 3 


$ Easy way to build Webserver, Database Server with AppServ :-) 


到 


[mml el ml Fr er 
图 12-11 AppServ 安装 成 功 后 的 访问 页 面 


此 外 ， 还 可 以 在 网 页 浏览 器 地 址 栏 中 输入 “http://localhost/phpinfo.php” 并 按 Enter 键 ， 
出 现 如 图 12-12 所 示 的 页 面 ， 在 此 可 查看 PHP、Apache 以 及 MySQL 的 相关 配置 信息 。 
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[windowsNT SMARTBEAN 51 buid 2600 
[wy22008180120 


scrpt /nologo configurejs "erable -snapsnot-buld™ ~ wth-gd—share 
Pt rs nt rt 
PROGRA~2)MICRO: 


[7 > 用 
图 12-12 服务 器 配置 信息 查询 
12.1.3 ”php.ini 文件 的 配置 
AppServ 安装 完成 后 , 在 其 安装 目录 下 找到 php5 文件 夹 , 将 如 图 12-13 所 示 的 php.ini- 
dist 文件 重 命名 为 php.ini。 


-OP ma| 国 -XX 只 半 六 间 队 


ME ET 


文件 和 文件 兴 任 务 a PhpSapachez_2 dll 
加 这 人 文件 phpS spachs2_2_£ilter. all 


国生 这 人 文件 到 | Yeb 
四 风 同 FRR 此 


了 这 个 文 伯 


其 它 位 置 


图 12-13 重 命名 php.ini-dist 文件 


为 了 网 站 服务 器 安全 起 见 ， 还 要 修改 部 分 PHP 配置 参数 。 打开 php.ini 文件 , 然后 进行 
如 下 操作 : 

口 ” 找 到 全 局 变量 开关 register_globals， 默 认 值 为 On， 为 安全 起 见 ， 在 网 站 正式 运行 
后 要 关闭 此 选项 ， 即 设置 为 :register_globals = Off。 

口 ”找到 错误 显示 开关 display_errors, 默认 值 为 On, 在 网 站 正式 运行 后 要 关闭 此 选项 ， 
即 设 置 为 : display_errors = Off。 

口 设置 文件 上 传 时 使 用 的 临时 目录 upload_tmp_dir。 默认 情况 下 ，AppServ 安装 完毕 
后 不 会 对 该 项 进行 设置 ,为 避免 在 PHP 文件 上 传 时 报错 , 用 户 应 进行 必要 的 设置 ， 
如 设置 为 : upload tmp_dir ="e:\php5\uploads\。 

AppServ 安装 完毕 后 ， 系 统 自 动 将 目录 AppServwwww 设置 为 默认 的 网 站 文档 的 根 目录 ， 
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用 户 也 可 根据 需要 进行 修改 , 其 方法 是 : 选择 “开始 ”一 “程序 ”一 AppServ 一 Configuration Server 
一 Apache Edit the httpd.conf Configuration File 命 令 , 即 可 打开 Apache 的 配置 文件 httpd.conf， 
找到 DocumentRoot 选项 , 对 其 进行 更 改 即 可 , 如 设置 为 : DocumentRoot "e:/AppServ/www"。 


12.2 ”实验 一 : 成 绩 管理 系统 的 设计 与 实现 


按照 12.1 节 所 叙述 的 方法 , 配置 好 PHP 项 目 开 发 环境 后 , 即 可 在 此 平台 上 做 一 些 实验 
项 目 ， 首 先 做 一 个 比较 简单 的 学 生成 绩 管 理 系统 的 实验 。 


12.2.1 实验 项 目 设 计 目 的 


掌握 利用 MySQL 数据 库 管理 系统 来 设计 用 户 数据 库 的 基本 技术 ， 包 括 如 何 创 建 数据 
库 , 如 何 创建 数据 库 表 , 了 解 MySQL 数据 库 所 支持 的 常见 数据 类 型 , 进一步 掌握 相关 SQL 
语句 功能 及 语法 ， 掌 握 如 何 利用 正则 表达 式 规范 用 户 提交 的 数据 。 熟 悉 在 PHP 程序 中 连接 
数据 库 的 常用 方法 。 


12.2.2 需求 分 析 及 功能 描述 
本 次 实验 结束 后 所 形成 的 软件 产品 应 满足 的 用 户 需求 及 功能 如 下 : 


口 学 生成 绩 查 询 。 

口 学 生 信息 查询 。 

整个 项 目的 界面 大 致 要 求 如 图 12-14 所 示 ， 学 生 在 做 实验 时 可 根据 现 有 的 网 页 素材 和 
计算 机 环境 灵活 处 理 。 


人 总 于 名 
生硬 机 豆油 ?8 
隆 序 设计 与 语言 。 80 


图 12-14 学 生成 绩 管理 系统 功能 界面 
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12.2.3 数据库 设计 


为 实现 成 绩 查 询 系统 的 预期 功能 ， 应 在 MySQL 中 设计 一 个 数据 库 〈StuScoreDB ) ， 
其 中 包含 3 个 数据 表 、 一 个 视图 以 及 一 个 存储 过 程 ， 本 次 实验 所 涉及 的 数据 库 和 数据 表 可 


通过 MySQL 数据 库 可 视 化 管理 工具 phpMyAdmin 和 Navicat MySQL 设计 实现 .如 表 12-1 一 
表 12-3 是 各 数据 表 的 结构 。 
表 12-1 成 绩 表 结构 
字段 名 称 备 注 
学 号 第 一 主键 
课程 号 第 二 主键 
成 绩 
字段 名 称 数据 类 型 备 ” 注 
课程 号 char 主键 
课程 名 char 
开课 学 期 tinyint 
学 时 int 
学 分 int 
字段 名 称 许 ; 备注 
学 号 主键 
姓名 | char | : 
性 别 tinyint 
出 生日 期 date 
专业 char 


备注 一 

照片 

为 加 快 查询 学 生 各 个 成 绩 情况 ， 还 应 建立 一 个 视图 (xs _cj_kc) ， 该 视图 涉及 3 个 基 
表 : 学 生 名 单 、 课 程 表 和 成 绩 表 ， 其 实现 的 SQL 语句 如 下 : 


CREATE VIEW xs_c kc AS 
select 学 生 名 单 .学 号 ， 二 课程 表 .课程 号 ,课程 表 .课程 名 ,成 绩 表 .成 绩 from 成 绩 表 , 课 
程 表 , 学生 名 单 where (( 成 绩 = 学 生 名 单 .学 号 ) and (成 绩 表 .课程 号 = 课程 表 . 课 程 号 )) 


还 有 一 个 存储 过 程 〈storeprc cj) : 


CREATE PROCEDURE storeprc_cj (in_xh CHAR(6),in_kch CHAR(3),in_cj INT(4)) 
BEGIN 
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DECLARE in_count INT(4); 
DECLAREin_ xf TINYINT(1); 
DECLARE in_cjb_cj INT(4); 
SELECT 学 分 INTO in_xf FROM KCB WHERE 课程 号 =in_kch; 
SELECT COUNT(*) INTO in_count FROM CJB WHERE 学 号 =in_xh AND 课程 号 =in_kch; 
SELECT 成 绩 INTO in_cjb_cj FROM CJB WHERE 学 号 =in_xh AND 课程 号 =in_kch; 
IF in_count>0 THEN 
BEGIN 
DELETE FROM CJB WHERE 学 号 =in_xh and 课程 号 =in_kch; 
IF in_cjb_cj>60 THEN 
UPDATE XSB set 总 学 分 = 总 学 分 -in_xf WHERE 学 号 =in_xh; 
END IF; 
END; 
END IF; 
IF in_cjb_cj!=-1 THEN 
BEGIN 
INSERT INTO CJB VALUES(in_xh,in_kch,in_cj); 
IF in_cjb_cj>60 THEN 
UPDATE XSB SET 总 学 分 = 总 学 分 +in_xf WHERE 学 号 =in_xh; 
END IF; 
END; 
END IF; 
END 


12.2.4 ”代码 设计 


基于 本 程序 功能 的 描述 和 现 有 的 数据 库 结 构 ， 在 进行 代码 编写 时 应 结合 前 期 的 功能 需 
求 分 析 进 行 合理 的 代码 设计 ， 下 面 列 出 主要 模块 的 部 分 代码 。 


1. MySQL 数据 库 连接 模块 的 实现 代码 


<?php 

$server="localhost"; /| 服务器 名 
S$user="root"; /用户 名 
$password="ld1224"; /密码 

$database=" StuScoreDB"; /数据 库 名 
Sconn=mysql_connect($server, $user,$password); // 连 接 字符 串 
mysql_select_db($database, $conn); /1 选择 并 打开 数据 库 
mysql_query("SET NAMES gb2312"); // 设 置 字符 集 

?> 


2. 显示 学 生 信 息 模块 的 实现 代码 


<?php 
require "connection.php ; 
session_start(); 
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$number=$_GETTid1]; 

$_SESSION['number]=$number; 

$sql="select 备注 ,照片 fom 学 生 名 单 where 学 号 ='$number"; // 查 找 备注 和 照片 列 
$result=mysql_query($sq)l); 

@S$row=mysql_fetch_array($result); 

$BZ=$row[' 备 注 ]; 

$ZP=$row[' 照 片 ]; 

?> 

<html><head> 

<title> 学 生 附 加 信息 </title> 

</head> 

<body bgcolor="D9DFAA"> 

<br><br><br><table width="100" border="1"> 

<tr><td align="center"> 附 加 信息 </td></tr> 

<tr><td bgcolor="#CCCCCC" align="center"> 备 注 </td></tr> 

<tr><td><textarea rows="7" name="StuBZ"” ><?php if($BZ)echo $BZ;else echo " 暂 无 ?> 
</textarea></td></tr> 

</table></body> 

</html> 


3. 添加 学 生 信息 及 修改 学 生 信息 模块 的 实现 代码 


<html> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<body bgcolor="D9DFBB"> 
<div align="center"><font face=" 宋 体 " size="5" color="#008000"> 
<b> 录 入 学 生 信息 </b></font></div> 
<form name="frm1" method="post" action="AddStu.php" style="margin:0"> 
<table width="340" align="center"> 
<tr><td width="168"><span > 根据 学 号 查询 学 生 信息 :</span></td> 
<td><input name="StuNumber id="StuNumber" type="text" size="10"> 
<input type="submit" name="test” value=" 查 找 "></td></tr> 
</table> 
</form> 
<?php 
require "connection.php"; 
session_start(); 
Snumber=@$_POST['StuNumber'; 
$_SESSION['number]=$number; 
$sql="select * from 学 生 名 单 where 学 号 ='$number"; 
$result=mysql_query($sq)l); 
@S$row=mysql_fetch_array($result); 
if(($number!==NULL)&&(!$row)) // 判 断 学 号 是 否 合法 
echo "<script>alert( 没有 该 学 生 信息 ! ')</script>"; 
StimeTemp=strtotime($row[ 出 生日 期 ]); 
Stime=date("Y-n-j", $timeTemp); 
ss: 
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<form name="frm2" method="post" style="margin:0" enctype="multipart/form-data"> 
<table bgcolor=#CCCCCC" width="430" border="1" align="center" cellpadding="0" cellspacing="0"> 
<tr><td bgcolor="#CCCCCC" width="90"><span > 学 号 :</span></td> 
<td><input name="StuNum" type="text" size="35" value="<?php echo $row[ 学 号 ]; ?>"> 
<input name="h_StuNum" type="hidden" value="<?php echo $row[' 学 号 ]; ?>"></td></tr> 
<tr><td bgcolor="#CCCCCC" width="90"><span > 姓名 :</span></td> 
<td><input name="StuName" type="text” size="35” value="<?php echo $row[ 姓 名 和]; ?>"> 
</td></tr> 
<tr><td bgcolor="#CCCCCC"><div > 性 别 :</div></td> 
<?php 
if($row[" 性 别 ]===0) 
je 
<td><input type="radio" name="Sex" value="1"><span > 男 </span> 
<input type="radio" name="Sex" value="0" checked="checked"><span > 女 


</span></td> 
<?php 
1 
else 
{2> 
<td><input type="radio" name="Sex" value="1" checked="checked"> 
<span > 男 </span> 
<input type="radio" name="Sex" value="0"><span > 女 </span></td> 
<?php 
} 
2 
</tr> 


<tr><td bgcolor="#CCCCCC"><span > 出 生日 期 :</span></td> 
<td><input name="Birthday" size="30" type="text" value="<?php if($time) echo $time;?>"></td></tr> 
<tr><td bgcolor="#CCCCCC"><span > 专业 :</span></td> 
<td><input name="Project" size="30" type="text" value="<?php echo $row[' 专 业 "];?>"></td></tr> 
<tr><td bgcolor="#CCCCCC"><span > 总 学 分 :</span></td> 
<td><input name="StuZXF"” size="30”type="text”value="<?php echo S$row[ 总 学 分 人 ?>" 
readonly></td></tr> 
<tr><td bgcolor="#CCCCCC"><span > 备注 :</span></td> 
<td><textarea cols="34" rows="4" name="StuBZ" > 
<?php echo $row[' 备 注 ']; ?></textarea></td></tr> 
<tr><td bgcolor="#CCCCCC" height="150"><span > 学 生 照 片 :</span></td> 
<td align="center > 


<br><input type="file" name="file"></td></tr> 

<tr><td align="center" colspan="2" bgcolor="#CCCCCC"> 

<input name="b" type="submit" value=" 修 改 " >&nbsp;&nbsp; 

<input name="b" type="submit" value=" 添 加 " /> 

&nbspi&nbsp;<input name="b" type="submit" value=" 删 除 " >&nbsp;&nbsp; 
<input name="b" type="button" value=" 退 出 ” onClick="window.location='main.html"> 
</td></tr> 

</table></form></body> 

</html> 

<?php 

S$Num =$_POST[StuNum'; 
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$XH=$_POST[h_StuNum1: 

Sname=$_POST[StuName']; 

$sex=$_POST[Sex'; 

Sbirthday=$_POST[Birthday':; 

$project=$_POST['Project]; 

$points=$_POST['StuZXF']; 

$note=$_POST['StuBZ1]; 

Stmp_file=$_FILES["file"]["tmp_name"]; 

Shandle=fopen($tmp_file,'r’); 

Spicture=addslashes(fread($handle,filesize($tmp_file))); 
S$checkbirthday=preg_match(/^\d{4}-(0?\d|1?[012])-(0?\dI[12]\d|3[01])$/",$birthday);”// 正 则 表达 式 
function test($xuehao, $name, $checkbirthday, $tmp_file) // 该 函数 用 于 验证 表单 数据 


if($xuehao==NULL) 


{ 
echo "<script>alert(' 学 号 不 能 为 空 !);location.href='AddStu.php';</script>"; 
exit; 


} 
else if($name==NULL) 


{ 
echo "<script>alert(' 姓 名 不 能 为 空 !);location.href='AddStu.php';</script>"; 
exit; 
} 
else if($checkbirthday==0) // 判 断 日 期 是 否 符合 格式 要 求 
{ 
echo "<script>alert(' 日 期 格式 错误 !");location.href='AddStu.php';</script>"; 
exit; 
} 
else 
if($tmp_file) // 如 果 上 传 了 照片 
{ 
Stype=$_FILES['file[type']; /1 上 传 文件 的 格式 
STpsize=$_FILES['file']['size']; // 图 片 的 大 小 


if((($type!="image/gif’)&&($type!="image/jpeg")&&($type!="image/pjpeg")&& 
($type!="image/bmp"))) 


! echo "<script>alert(' 照 片 格式 不 对 !);location.href='AddStu.php';</script>"; 
exit; 

D 

else if($Tpsize>100000) 

: echo "<script>alert(' 照 片 尺寸 太 大 !);location.href='AddStu.php';</script>"; 
exit; 

} 


} 
} 
if(@$_POST["b"]==' 修 改 ') 
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echo "<script>if(lconfirm(' 确 认 修改 )) return FALSE;</script>"; 
test($xuehao, $name,$checkbirthday,$tmp_file); 
if($xuehao!=$XH) 
echo"<script>alert(' 学 号 非法 ， 无 法 修改 !):location.href='AddStu.php';</script>" 
else 
时 
if(I$tmp_file) 
l $update_sql="update 学 生 名 单 set 姓名 ='$name', 性 别 =$sex, 出 生日 期 ='$birthday'， 
专业 ='$project', 备注 ='$note' where 学 号 ='$XH"; 
} 


else 


$update_sql="update 学 生 名 单 set 姓名 ='$name", 性 别 =$sex, 出 生日 期 ='$birthday， 
专业 ='$project', 备 注 ='$note'， 照 片 ='$picture' where 学 号 ='$XH"; 
} 
$update_result=mysql_query($update_sql); 
if(mysql_affected_rows($conn)!=0) 
echo "<script>alert(' 修 改 成 功 (");location.href='AddStu.php';</script>"; 
else 
echo "<script>alert(' 失 败 ， 请 检查 输入 信息 !");location.href='AddStu.php';</script>"; 
} 


1 

if(@$_POST["b"]==' 添 加 ') 

{ 
test($xuehao, $name, $checkbirthday,$tmp_file); 
$s_sql="select 学 号 from 学 生 名 单 where 学 号 ='$xuehao”"; 
$s_result=mysql_query($s_sql); 
$s_row=mysql_fetch_array($s_result); 


if($s_row) 
echo "<script>alert(' 已 存在 ， 无 法 添加 !");location.href='AddStu.php';</script>"; 
else 
if(!I$tmp_file) // 车 没有 图 片 则 不 向 照片 字段 插入 内 容 
{ 


S$insert_sql="insert into 学 生 名 单 (学 号 ,姓名 ,性 别 ,出 生日 期 ,专业 ,总 学 分 ,备注 ) 
values('$xuehao','$name', $sex,'$birthday','$project',0,'$note'’)"; 


} 

else 
Sinsert_sql="insert into 学 生 名 单 (学 号 ,姓名 ,性 别 ,出 生日 期 ,专业 ,总 学 分 ,备注 ,照片 ) 
values($xuehao','$name',$sex,'$birthday',$project,0,,$note','$picture ) ; 

上 


$insert_result=mysqlL_query($insert_sql); 
if(mysql_affected_rows($conn)!=0) 
echo "<script>alert(' 添 加 成 功 !");location.href='AddStu.php';</script>"; 
else 
echo"<script>alert(' 失 败 ， 检 查 输入 !");location.href='AddStu.php';</script>"; 
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} 
1 
i(@$_POST["b"]==' 删 除 ') 
{ 
if($xuehao==NULL) 
{ 
echo "<script>alert( 请 输入 要 删除 的 学 号 !");location.href='AddStu.php';</script>"; 
由 
else 
{ 
$d_sql="select 学 号 from 学 生 名 单 where 学 号 ='$xuehao"; 
$d_result=mysql_query($d_sql); 
$d_row=mysql_fetch_array($d_result); 
If(l$d_row) // 学 号 如 果 不 存在 则 提示 
echo "<script>alert(' 不 存在 ， 无 法 删除 !");location.href='AddStu.php';</script>"; 
else 
{ 
$del_sql="delete from 学 生 名 单 where 学 号 ='$xuehao"; 
$del_result=mysql_query($del_sql) or die(' 删 除 失败 ! 7); 
if($del_result) 
echo "<script>alert(' 删 除 ".$xuehao." 成 功 !");location.href='AddStu.php';</script>"; 
bh 
} 
1 
?> 


4. 学 生成 绩 录 入 与 编辑 模块 的 实现 代码 


<html> 
<head><title> 学 生 信 息 查 询 </title> 
<meta http-equiv="Content-type" content= "text/html; charset=gb2312"> 
</head> 
<body bgcolor="D9DFAA"> 
<div align="center"><font face=" 宋 体 " size="5" color="#008000"><b> 成 绩 信息 录入 </b></font></div> 
<form action="AddStuScore.php" method="get" style="margin:0"> 
<table width="450" align="center"> 
<tr><td width="60" bgcolor="#CCCCCC"> 课 程 名 :</td> 
<td width=50><select name="KCName" > 
<option value=" 请 选择 "> 请 选择 </option> 
<?php 
require "connection.php"; 
$kc_sql="select distinct 课程 名 from 课程 表 "; // 查 课程 
$kc_result=mysql_query($kc_sql); 
while($kc_row=mysql_fetch_array($kc_result)) 
{ 
echo "<option>".$kc_row[' 课 程 名 1]."</option>"; // 输 出 课程 名 到 下 拉 列 表 框 中 
?> 
</select></td> 


<td width="60" bgcolor="#CCCCCC"> 专 业 :</td> 
<td width=50><select name="ZYName'" > 
<option value=" 请 选择 "> 请 选择 </option> 
<?php 
$zy_sql="select distinct 专业 from 学 生 名 单 "; // 查 找 专业 
$zy_result=mysql_query($zy_sql); 
while($zy_row=mysql_fetch_array($zy_resultb) 
{ 
echo "<option>".$zy_row[ 专 业 ]."</option>"; // 输 出 专业 名 到 下 拉 列 表 框 中 
H 
?> 
</select></td> 
<td width="60" align="center > 
<input type="submit" name="Query" value=" 查 询 "></td></tr> 
</table> 
</form> 
<?php 
require "connection.php"; 
S$KCName=$_GET[KCName'; 
$ZYName=$_GET[ZYName']; 
echo "<br><div align=center >$KCName</div>"; // 输 出 课程 名 
echo "<table width=450 border=1 align=center cellpadding=0 cellspacing=0 >"; 
echo "<tr bgcolor=#CCCCCC height=25 align=center><td> 学 号 </td>"; 
echo "<td> 姓 名 </td>"; 
echo "<td> 成 绩 </td>"; 
echo "<td width=160> 操 作 </td></tr>"; 
if(ISKCName&&!I$ZYName) 
有 
for($i=0;$i<10;$i++) 
{ 
echo"<tr height=28><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td>"; 
} 
} 
else 
{ 
if($KCName==" 选 择 ") // 如 果 未 选课 程 则 进行 相应 提示 
echo "<script>alert(' 选 择 课程 ');location.href='AddStuScore.php'</script>"; 
else 


中 
Stotal=0; // 初 始 化 总 记录 数 的 值 为 0 
if($ZYName==" 选 择 ") 
电 
$XS_sql="select 学 号 ,姓名 from 学 生 名 单 "; 
} 
else 
上 
$XS_sql="select 学 号 ,姓名 from 学 生 名 单 where 专业 ='$ZYName'"; 


$XS_result=mysql_query($XS_sql); 
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S$total=mysql_num_rows($XS_result); 1/ 计算 总 记录 数 
S$page=isset($_GET[page'])?intval($_GET[page'):1; 
$url='AddStuScore.php'; /本 页 URL 
Snum=10; 


$pagenum=ceil($total/$num); 
$page=min($pagenum,$page); 
$prepg=$page-1; 
$nextpg=($page==$pagenum? 0: $page+1); 
$offset=($page-1)*$num; 
$endnum=$offset+$num; 
Snew_sql=$XS_sql." limit ".($page-1)*$num.",".$num; 
$new_result=mysql_query($new_sql); 
while($new_row=mysql_fetch_array($new_result) 
{ 
list($number, $name)=$new_row; // 列 出 结果 值 
$CJ_sql="select 成 绩 from 成 绩 表 where 学 号 =$number 
and 课程 号 =(select 课程 号 from 课程 表 where 课程 名 =$KCName') ; 
$CJ_result=mysql_query($CJ_sql); 
$CJ_row=mysql_fetch_array($CJ_result); 
$points=$CJ_row[ 成 绩 ]; // 取 出 成 绩 值 
echo "<input type=hidden value=$KCName id='course'>"; 
echo "<tr align=center><td width=110>$number</td>"; 
echo "<td width=110>$name</td>"; 
echo "<td width=110><input id='points-$number type=text size=12 value=$points> 
</td>"; 
echo "<td><ahref=#onclick=\"save(this.id,'$number'")\"id='keep-$number'> 保存 </a> 
&nbsp;&nbsp;"; 
echo "<ahref=#onclick=\"save(this.id,'$number')\"id='delete-$number'> 删 除 </a> </td> 
</tr>"; 
b 
echo "</table>"; 
$pagenav=""; 
if($prepg) 
$pagenav.="<a href='$url?page=$prepg&KCName=$KCName&ZYName=$ZYName' 
> 上 一 页 </a> "; 
for($i=1;$i<=$pagenum;$i++) 


{ 
if($page==$i) $pagenav.=$i.”"; 
else 
$pagenav.=" <a href='$url?page=$i&KCName=$KCName&ZYName= $ZYName'>$i 
</a> "; 
1 
if($nextpg) 


S$pagenav.=" <a href='$url?page=S$nextpg&KCName=$KCName&ZYName =$ZYName’ 
> 下 一 页 </a> "; 
$pagenav.=" 共 (".$pagenum.") 页 "; 
echo "<br><div align=center ><b>".$pagenav."</b></div>"; // 输 出 分 页 导航 


?> 
<script> 
var xmlHttp; 
function GetXmlHttpObject() 
{ 
var xmlHttp=null; 
try 
ud 
xmlHttp=new XMLHttpRequest(); 
} 
catch(e) 
{ 
try 
{ 
ttp=new ActiveXObject("Msxml2.XMLHTTP"); 
4 
catch(e) 
{ 
mlHttp=new ActiveXObject("Microsoft.XMLHTTP"); 
b 
1 
return xmlHttp; 
} 
function save(str,num) 
{ 
xmlHttp=GetXmlHttpObject(); 
var kcname=document.getElementByld("course").value; 
var points=document.getElementByld("points-"+num).value; 
var url="StuCJ.php"; 
Url=url+"?id="+str+"&points="+points+"&kcname="+kcname; 
url=url+"&sid="+Math.random(); /添加 一 个 随机 数 ， 以 防 服务 器 使 用 缓存 的 文件 
xmlHttp.open("GET ,urltrue); 
xmlHttp.send(null); // 向 服务 器 发 送 HTTP 请 求 
xmlHttp.onreadystatechange = function() 
{ 
if (xmlHttp.readyState==4 || xmlHttp.readyState=="complete") 
{ 
alert(xmlHttp.response Text); 
if(xmlHttp.responseText==' 删 除 成 功 ! ) 
document.getElementByld("points-"+num).value=”; 
bh 
by 
} 
</script> 
?> 
</body> 
</html> 
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5. 成 绩 查 询 模块 的 实现 代码 


<html> 
<head><title> 学 生成 绩 查 询 </title></head> 
<body bgcolor="D9DFAA"> 
<div align="center"><font face=" 宋 体 " size="5" color="#008000"> 
<b> 学 生成 绩 查询 </b></font></div> 

<form name="frm1" method="post" action="ShowStuKC.php" style="margin:0"> 
<table width="500" align="center"> 
<tr><td width="60"><span > 学 号 :</span></td> 
<td width="160"><input name="StuNum" type="text" size="20"></td> 
<td><input type="submit" name="query” value=" 查 找 "></td> 
<td>&nbsp;</td></tr> 
</table> 
</form> 
<?php 
require "connection.php"; 
session_start(); 
Snumber=@$_POST['StuNum'; 
$_SESSION['number]=$number; 
$sql1="select 课程 号 ,课程 名 ,成 绩 from xs_kc_cj where 学 号 ='$number"; 
$sql2="select 姓名 ,总 学 分 ,照片 from 学 生 名 单 where 学 号 ='$number"; 
$result1=mysql_query($sql1); 
$result2=mysql_query($sql2); 
echo "<table width=500 height=350 align=center>"; 
echo "<tr><td>"; 
echo "<table width=350 height=340 border=1 cellpadding=0 cellspacing=0>"; 
echo "<tr bgcolor=#CCCCCC >"; 
echo "<td width=100> 课 程 号 </td>"; 
echo "<td width=150> 课 程 名 </td>"; 
echo "<td width=100> 成 绩 </td></tr>"; 
if(ISresult1) 
{ 

for($i=0;$i<12;$i++) 

! 

echo "<tr><td>&nbsp; &nbsp;</td><td>&nbsp; &nbsp;</td><td>&nbsp; &nbsp;</td></tr>"; 
1 


由 

else 

{ 
$js=0; 
while($row1=mysql_fetch_array($result1)) 


List($KCH,$KCM,$CJ)=$row1; 
echo "<tr ><td>$KCH&nbsp;</td>"; 
echo "<td>$KCM&nbsp;</td> "; 
echo "<td>$CJ&nbsp;</td></tr>"; 


9$js++; 
} 
for($i=0;$i<12-$js;$i++) 
{ 
echo "<tr><td>&nbsp;</td><td>&nbsp;</td><td>&nbsp;</td></tr>"; 
) 


} 


echo "</table></td>"; 
@S$row2=mysql_fetch_array($result2); 
list($XM,$ZXF,$ZP)=$row2; 
if($number&&(!$XM)) 
echo "<script>alert(' 学 号 错误 !");location.href='ShowStuKC.php';</script>"; 
else 
{ 
echo "<td><table width=150 height=340 border=1 cellpadding=0 cellspacing=0>"; 
echo "<tr><td height=25 bgcolor=#CCCCCC> 姓 名 :</td></tr>"; 
echo "<tr><td height=25 align=center>$XM&nbsp;</td></tr>"; 
echo "<tr><td height=25 bgcolor=#CCCCCC> 总 学 分 : </td></tr>"; 
echo "<tr><td height=25 align=center>$ZXF&nbsp;</td></tr>"; 
echo "<tr><td align=center>"; 
echo "<input type=button name=exit value= 退 出 onclick=\"window.location='main.html\"> 
</td></tr>"; 
echo "</table></td>"; 
} 
echo "</tr></table>"; 
?> 
</body> 
</html> 


6. 成 绩 修改 与 删除 模块 的 实现 代码 


<?php 
require "connection.php"; 
header("Content-Type:text/html;charset=gb2312"); 
$id=$_GET[id]; 
Skcname=$_GET['kcname']; 
S$points=$_GET['points']; 
S$array=explode("-", $id); 
$action=$array[0]; 
Snumber=$array[1]; 
$kc_sql="select 课程 号 from 课程 表 where 课程 名 ='$kcname'"; 
$kc_result=mysql_query($kc_sql); 
$kc_row=mysql_fetch_array($kc_result); 
$kcnumber=$kc_row[ 课 程 号 1]; 
if($action=="keep") 
{ 

if($points) 
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S$cj_sql="CALL storeprc_cj (‘$number','$kcnumber', $points)"; 
S$cj_result=mysql_query($cj_sq)l); 
if($cj_result) 
echo ' 保 存 成 功 !; 
else 
echo "保存 失败 !"; 
} 
else 


echo "成 绩 值 为 空 ， 请 输入 成 绩 !"; 


} 
if($action=="delete") 
{ 
$cj_sql="CALL storeprc_cj (‘$number','$kcnumber',-1)"; 
$cj_result=mysql_query($cj_sql); 
if(mysql_affected_rows($conn)!=0) 
echo "删除 成 功 !"; 
else 
echo "删除 失败 !"; 


12.3 ”实验 二 : 用 户 管理 系统 的 设计 与 实现 


第 9 章 详 细 讲述 了 在 PHP 中 采用 面向 对 象 程序 设计 技术 来 编写 程序 代码 的 方法 , 采用 
面向 对 象 编程 思想 ， 将 使 编程 不 再 是 非常 困难 的 事 ， 本 次 实验 要 求 利用 面向 对 象 程序 设计 
技术 来 实现 。 


12.3.1 ”实验 项 目 设计 目的 


深入 理解 面向 对 象 程序 设计 中 类 、 对 象 、 封 装 、 类 的 继承 等 概念 ， 熟 悉 利 用 PHP 语言 
来 定义 类 和 对 象 的 方法 ， 熟 练 掌握 如 何 访问 对 象 ， 进 一 步 掌 握 相 关 SQL 语句 功能 及 语法 
熟悉 在 PHP 程序 中 连接 数据 库 的 常用 方法 。 


12.3.2 需求 分 析 及 功能 描述 


本 次 实验 结束 后 所 形成 的 软件 产品 应 满足 的 用 户 需求 及 功能 如 下 : 
口 ”用户 的 系统 登录 。 

用 户 角色 及 权限 的 分 配 。 

系统 管理 员 添加 系统 新 用 户 。 

系统 管理 员 修 改 用 户 信息 。 

系统 管理 员 删 除 用 户 信 息 。 


OO 
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整个 项 目的 功能 界面 大 致 要 求 如 图 12-15 一 图 12-18 所 示 , 学 生 在 做 实验 时 可 根据 现 有 
的 网 页 素材 和 计算 机 环境 灵活 处 理 。 


及 用 户 管理 系 续 -Vinders 


GO 


这) 二 月 PS 和 | 男 | 


可 站 让 天 只 月 P 秆 理 和 入 


身份 验证 您 此 次 章 录 记 功 只 
请 往 入 用 户 名 和 密码 用 户 管理 系统 
A 登录 记功 ， 吹 迎 你 光量， 系统 管理 郧 1 
窗 到 
你 有 下 列 系统 操作 权限 
EE 


用 户 管理 像 改 恋 码 退出 登录 


图 12-15 用 户 管理 系统 的 用 户 登 录 页 面 图 12-16 用 户 登 录 成 功 后 的 页 面 


司 用 户 广 册 - Windows 
by hp /localhost/ Pb: 


(eB rr | 


训 中 车 夹 。 届 系 统 用 户 管理 | 图 | 


用 疡 清和 E 
用 户 姓名 
用 户 号 姓名 操作 用 户 密码 
Admin 系统 管理 员 修改 则 除 
u001 zengjiaqing 修改 刘 除 
u002 yangdong 修改 别 除 
u003 周二 娃 修改 则 除 
还 加 新 用 户 
图 12-17 用 户 查 询 及 修改 页 面 图 12-18 系统 管理 员 添 加 新 用 户 


12.3.3 ”数据 库 设计 
为 实现 用 户 管理 系统 的 预期 功能 ， 应 在 MySQL 中 设计 一 个 数据 库 〈userdatabase) ， 
其 中 包含 一 个 数据 表 ， 其 数据 表 的 结构 如 表 12-4 所 示 。 
表 12-4 ”课程 表 结构 


字段 名 称 数据 类 型 数据 长 度 是 否 允 许 为 空 备注 
50 i 


否 主键 


12.3.4 代码 设计 


基于 本 程序 功能 的 描述 和 现 有 的 数据 库 结构 ， 在 进行 代码 编写 时 应 结合 前 期 的 功能 需 
求 分 析 进 行 合理 的 代码 设计 ， 下 面 列 出 主要 模块 的 部 分 代码 。 
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用 户 (Users) 类 定义 的 实现 代码 


<?PHP 
class Users 


{ 


var $conn; 
public $UID; /用 户 号 
public $UserPwd; /用 户 密码 
public $username; // 显 示 名 称 
function __construct() // 定 义 构造 函数 
{ 
Sthis->conn = mysqli_connect("localhost", "root", "|d1224", "userdatabase"); 
// 连 接 数据 库 
mysqli_query($this->conn, "SET NAMES gbk"); 
1 
function __destruct() /定义 析 造 函数 


{ 
mysqli_close(S$this->conn); /| 关闭 连接 


} 
function exists($usen) /定义 类 的 方法 ， 判 断 指定 用 户 是 否 存在 
{ 
Sresult = $this->conn->query("SELECT * FROM Users WHERE UID=”. $user . ”); 
If($row = $result->fetch_row())、 
{ 
Sthis->UID = $user; 
Sthis->UserPwd = $row[1]; 
Sthis->username = $row[2]; 
return true; 
else 
return false; 


} 
function verify($user, $pwd) // 定 义 类 的 一 个 方法 ， 判 断 用 户 号 和 密码 是 否 存 在 


$sql = "SELECT * FROM Users WHERE UID=" . $user ." AND UserPwd=" . $pwd ."™; 
Sresult = $this->conn->query($sql); 
if($row = $result->fetch_row!()) 
Sthis->UID = $user; 
Sthis->UserPwd = $pwd; 
Sthis->username = $row[2]; 
return true; 
} 
else 
return false; 


} 
function load_users() /定义 类 的 方法 ， 用 于 显示 所 有 用 户 信息 


1 
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$sql = "SELECT * FROM Users"; 
Sresult = $this->conn->query($sql); 
Return $result; 
} 
function insert() // 定 义 类 的 方法 ， 添 加 新 用 户 
时 
$sql = "INSERT INTO Users VALUES(™ . $this->UID . "，”. S$this->UserPwd .",™. 
Sthis->username . ")"; 
Sthis->conn->query($sql); 


“二 本 updateShowName() /修改 用 户 名 
$sql = "UPDATE Users SET username=”. $this->username . " WHERE UID=". $this 
->| oh 
a Giese 
1 updatePassword() /定义 类 的 方法 ， 修 改 用 户 密码 
{ 


$sql = "UPDATE Users SET UserPwd=" . S$this->UserPwd . ”WHERE UID='”. 
S$this->UID . ”; 
$this->conn->query($sql); 


1 
function delete() /定义 类 的 方法 ， 用 于 删除 用 户 
1 


$sql = "DELETE FROM Users WHERE UID=" . $this->UID . ”"; 
Sthis->conn->query($sql); 


} 


?> 


2. 用 户 号 与 用 户 密码 验证 模块 的 实现 代码 


<?PHP 

include('Users.php'); // 将 Users 类 包含 到 此 处 
$user = new Users(); 

session_start(); 

iflisset($_SESSION[Passed])) 


$_SESSION[Passed'] = False; 


} 

if($_SESSION['Passed']==False) 

{ 
S$UID =$_POST[UID1]; 
S$UserPwd =$_POST[UserPwd1]; 


if($UID == ”) 

$Errmsg = "请 输入 用 户 号 和 密码 "; 
else 
{ 
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if(I$user->verify($UID, $UserPwd)) 


$Errmsg = "用 户 号 或 密码 不 正确 "; 
b 
else 
{ 
echo(" 您 此 次 登录 成 功 啦 "); 
$_SESSION[Passed'] = True; 
$_SESSION[UID]= $UID; 
$_SESSION['username'] = $user->username; 
I/!$_SESSION[username'] = $row[2]; 
} 
; 
1 
if(l$_SESSION[Passed]) 
1 
?> 
<HTML> 
<HEAD><TITLE> 输 入 用 户 号 及 密码 </TITLE></HEAD> 
<BODY> 
<script Language="JavaScript"> 
function ChkFields() 
{ 
if (document.MyForm.UID.value==") 
window.alert ("请 输入 用 户 号 !") 
return false 
b 
return true 
1 
</script> 


<p align="center"><font ”color="#FF0000" size="5" face=" 隶 书 "> 身 份 验 证 </font></p> 

<p align="center"><font color="#800000"> <?PHP echo($Errmsg); ?></font></p> 

<form method="POST" action="<?PHP $_SERVER[PHP_SELF] ?>" name="MyForm" 
onsubmit ="return ChkFields()"> 

<p align="center"> 用 户 号 : &nbsp; <input type="text" name="UID" size="20"></p> 

<p align="center"> 密 &nbsp; 码 : &nbsp; <input type="password" name="UserPwd" size="20" 
> </p> 

<p align="center"><input type="submit” value=" 提 交 " name="B1"><input type="reset" value 
=" 重 写 " name="B2"></p> 


</form> 
<p align="center"> </p> 
</BODY></HTML> 
<?PHP 
exit(™); 

} 

?> 
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3. 新 用 户 添加 模块 的 实现 代码 


<?PHP 

include('ChkPwd.php'); 

if($_SESSION['UID'] <> "Admin") 

{ 
echo(" 不 是 Admin 用 户 ， 没 有 此 权限 "); 
exit(); 

}?> 

<html> 

<head><title> 用 户 注册 </title></head> 

<script Language="JavaScript"> 

function ChkFields() { 

if (document.myform.UID.value==") { 
window.alert ("请 输入 用 户 号 !"); 
myform.UID focus(); 
return false 

1 

if (document.myform.UID.value.Length<=2) { 
window.alert ("用 户 号 长 度 不 得 小 于 2。"); 
myform.UID.focus(); 
return false 

} 

if (document.myform.Pwd.value.length<6) { 
window.alert ("新 密码 长 度 不 得 小 于 6。"); 
myform.Pwd .focus(); 
return false 

} 

if (document.myform.Pwd.value==") { 
window.alert ("输入 新 密码 !"); 
myform.Pwd .focus(); 
return false 

1 

if (document.myform.Pwd1.value==") { 
window.alert ("请 确认 新 密码 !"); 
myform.Pwd1.focus(); 
return false 

if (document.myform.Pwd.value!=document.myform.Pwd1.value) { 
window.alert ("两 次 输入 的 新 密码 必须 相同 !"); 
return false 

) 

return true 

} 

</script> 

<body> 
<form method="POST" action="UserSave.php" name="myform" onSubmit="return ChkFields()"> 
<h3></h3> 
<p align="center"> 用 户 基本 信息 </p><input type="hidden" name="flag" value="new"> 
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<table align="center" border="1" cellpadding="1" cellspacing="1" width="473" bordercolor="#008000" 
bordercolordark="#FFFFFF"> 
<tr> 

<td align=left bgcolor="#E1F5FF" width="165"> 用 户 号 </td> 

<td width="292"><input type="text" name="UID" size="20"></td> 
</tr> 
<tr> 

<td align=left bgcolor="#E1F5FF" width="165"> 用 户 姓 名 </td> 
<td width="292"><input type="text" name="username" size="20"></td> 
</tr> 
<tr> 

<td align=left bgcolor="#E1F5FF" width="165"> 用 户 密码 </td> 

<td width="292"><input type="password" name="Pwd" size="20"></td> 
</tr> 
<tr> 

<td align=left bgcolor="#E1F5FF" width="165"> 密 码 确认 </td> 

<td width="292"><input type="password" name="Pwd1" size="20"></td> 

</tr> 
</table> 
<p align="center"><input type="submit" value=" 提 交 " name="B2"></p> 

</form></body> 
</html> 


4. 用 户 密码 修改 模块 的 实现 代码 


<?PHP 

include(ChkPwd.php); 

S$UID =$_GET[UID1]; 

?> 

<html> 

<head> 

<title> 修 改 密码 </title> 

</head> 

<Script Language="JavaScript"> 
function ChkFields() { 


if (document.myform.OIdpwd.value==") 


alert(" 输 入 原始 密码 !") 


return false 
' (document.myform.Pwd.value.length<6) 
: alert(" 新 密码 长 度 至 少 要 为 6 位 !") 
return false 
人 (document.myform.Pwd.value!l=document.myform.Pwd1.value) 
1 


alert(" 两 次 输入 的 新 密码 必须 相同 !") 
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1 


return false 


return true 


} 
</Script> 
<body> 


<form method="POST" action="" name="myform" onSubmit="return ChkFields()"> 

<p align="center"> 修 改 密码 </p> 

<table align="center" border="1" cellpadding="1" cellspacing="1" width="263" bordercolor="#008000" 
bordercolordark="#FFFFFF" height="134"> 


<tr> 


</tr> 
<tr> 


</tr> 
<tr> 


</tr> 
<tr> 


</tr> 
</table> 


<td align=left width="86" height="18"> 用 户 号 </td> 
<td width="161" height="18"><?PHP echo($UID); ?></td> 


<td align=left width="86" height="23"> 旧 密码 </td> 
<td width="161" height="23"><input type="password" name="Oldpwd"></td> 


<td align=left width="86" height="23"> 新 密码 </td> 
<td width="161" height="23"><input type="password" name="Pwd"></td> 


<td align=left width="86" height="23"> 密 码 确认 </td> 
<td width="161" height="23"><input type="password" name="Pwd1"></td> 


<p align="center"> 
<input type="submit" value=" 提 交 "name="B2"></p> 


</form> 
<?PHP 


include('Users.php'); 

$oldpwd = $_POST[OIdpwd'; 

S$Pwd = $_POST[Pwd']; 

$user = new Users(); /定义 Users 对 象 
if(I$user->verify($UID, $Oldpwd)) 


{ 


echo(" 此 用 户 号 不 存在 或 密码 错误 !"); 


?> 


<Script Language="JavaScript"> 
setTimeout("history.go(-1)",1600); 
</Script> 


<?PHP 
} 


else 


{ 


$user->UID = $UID; 
$user->UserPwd = $Pwd; 
Suser->updatePassword(); 
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echo("<h2> 密 码 修改 成 功 ! </Ih2>"); 
} 


D> 

<Script Language="JavaScript"> 
setTimeout("window.close()",1600); 
</Script> 

</body> 

</html> 


12.4 实验 项 目 设计 总 结 与 提高 


通过 对 以 上 实验 项 目的 练习 , 可 以 总 结 出 以 下 内 容 : 虽然 实验 中 的 程序 功能 不 是 很 全 ， 
但 也 需 编 制 大 量 的 程序 ， 其 实 认 真 分 析 后 会 发 现 ， 虽 然 程 序 代 码 较 多 ， 但 其 操作 主要 集中 
在 对 数据 库 查 询 、 插 入 、 删 除 以 及 修改 等 操作 上 ， 而 这 些 操作 的 不 同 组 合 ， 就 构成 了 很 多 
典型 的 应 用 程序 。 通 过 本 实验 教程 的 练习 ， 读 者 应 当 深入 领会 PHP+MySQL 组 合 形式 的 数 
据 库 编程 思路 ， 掌 握 PHP Web 项 目 常见 的 解决 方案 。 此 外 ， 读 者 还 要 能 举一反三 ， 逐 渐 形 
成 具有 独立 设计 和 开发 Web 应 用 项 目的 能 
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